Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.sbin/sysinst Fix a few of the very stupid mistakes I mad...



details:   https://anonhg.NetBSD.org/src/rev/ff46eaadd0c4
branches:  trunk
changeset: 1000213:ff46eaadd0c4
user:      martin <martin%NetBSD.org@localhost>
date:      Sun Jul 14 15:36:57 2019 +0000

description:
Fix a few of the very stupid mistakes I made when converting this to
the abstract partitioning interface.

diffstat:

 usr.sbin/sysinst/partman.c |  69 +++++++++++++++++++++++++++++++++++++--------
 1 files changed, 56 insertions(+), 13 deletions(-)

diffs (124 lines):

diff -r 205d8e3ba283 -r ff46eaadd0c4 usr.sbin/sysinst/partman.c
--- a/usr.sbin/sysinst/partman.c        Sun Jul 14 13:55:43 2019 +0000
+++ b/usr.sbin/sysinst/partman.c        Sun Jul 14 15:36:57 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: partman.c,v 1.36 2019/07/13 17:13:36 martin Exp $ */
+/*     $NetBSD: partman.c,v 1.37 2019/07/14 15:36:57 martin Exp $ */
 
 /*
  * Copyright 2012 Eugene Lozovoy
@@ -454,11 +454,11 @@
                line = out;
        }
        if (no_size_display != NULL) {
-               wprintw(w, "%-34s (%s)", line, no_size_display);
+               wprintw(w, "   %-56s (%s)", line, no_size_display);
        } else {
                humanize_number(human, sizeof(human),
                    total, "", HN_AUTOSCALE, HN_B | HN_NOSPACE | HN_DECIMAL);
-               wprintw(w, "%-34s %s", line, human);
+               wprintw(w, "   %-56s %s", line, human);
        }
 }
 
@@ -2650,6 +2650,7 @@
        char buf[STRSIZE], dev[STRSIZE];
        part_id part_num = ((struct part_entry *)arg)[opt].id;
        struct pm_devs *pm_cur = ((struct part_entry *)arg)[opt].dev_ptr;
+       struct disk_partitions *parts = ((struct part_entry *)arg)[opt].parts;
        struct disk_part_info info;
        const char *mount_point, *fstype;
 
@@ -2668,11 +2669,16 @@
                                dev_status);
                        break;
                case PM_PART:
-                       pm_cur->parts->pscheme->get_part_device(pm_cur->parts,
-                           part_num, dev, sizeof dev, NULL, plain_name, false);
-                       pm_cur->parts->pscheme->get_part_info(pm_cur->parts,
+                       if (parts->pscheme->get_part_device != NULL)
+                               parts->pscheme->get_part_device(
+                                   parts,  part_num,
+                                   dev, sizeof dev, NULL, plain_name, false);
+                       else
+                               strcpy(dev, "-");
+                       parts->pscheme->get_part_info(parts,
                            part_num, &info);
-                       if (pm_cur->mounted[part_num] != NULL &&
+                       if (pm_cur->mounted != NULL &&
+                           pm_cur->mounted[part_num] != NULL &&
                            pm_cur->mounted[part_num][0] != 0)
                                mount_point = msg_string(MSG_pmmounted);
                        else
@@ -2754,6 +2760,8 @@
        int i = 0;
        size_t ii;
        struct pm_devs *pm_i;
+       struct disk_partitions *secondary;
+       const struct disk_partitioning_scheme *ps;
        struct disk_part_info info;
 
        if (arg != NULL)
@@ -2788,14 +2796,27 @@
                if (pm_i->no_part)
                        ((struct part_entry *)arg)[i].type = PM_SPEC;
                else {
+                       ps = pm_i->parts != NULL ? pm_i->parts->pscheme : NULL;
+                       secondary = NULL;
+
                        ((struct part_entry *)arg)[i].type = PM_DISK;
-                       for (ii = 0; ii < pm_i->parts->num_part; ii++) {
-                               if (!pm_i->parts->pscheme->get_part_info(
-                                   pm_i->parts, i, &info))
+
+                       for (ii = 0; pm_i->parts != NULL &&
+                           ii < pm_i->parts->num_part; ii++) {
+                               if (!ps->get_part_info(
+                                   pm_i->parts, ii, &info))
                                        continue;
-                               if (info.flags & (PTI_SEC_CONTAINER|
-                                   PTI_WHOLE_DISK|PTI_PSCHEME_INTERNAL|
-                                   PTI_RAW_PART))
+                               if (info.flags & PTI_SEC_CONTAINER) {
+                                       if (secondary == NULL &&
+                                           ps->secondary_scheme != NULL)
+                                               secondary = ps->
+                                                   secondary_partitions(
+                                                   pm_i->parts,
+                                                   info.start, false);
+                                       continue;
+                               }
+                               if (info.flags & (PTI_WHOLE_DISK|
+                                   PTI_PSCHEME_INTERNAL|PTI_RAW_PART))
                                        continue;
                                if (info.fs_type == FS_UNUSED)
                                        continue;
@@ -2803,6 +2824,28 @@
                                m->opts[i].opt_name = NULL;
                                m->opts[i].opt_exp_name = NULL;
                                m->opts[i].opt_action = pm_submenu;
+                               ((struct part_entry *)arg)[i].parts =
+                                   pm_i->parts;
+                               ((struct part_entry *)arg)[i].dev_ptr = pm_i;
+                               ((struct part_entry *)arg)[i].id = ii;
+                               ((struct part_entry *)arg)[i].type = PM_PART;
+                       }
+
+                       for (ii = 0; secondary != NULL &&
+                           ii < secondary->num_part; ii++) {
+                               if (!secondary->pscheme->get_part_info(
+                                   secondary, ii, &info))
+                                       continue;
+                               if (info.flags & (PTI_WHOLE_DISK|
+                                   PTI_PSCHEME_INTERNAL|PTI_RAW_PART))
+                                       continue;
+                               if (info.fs_type == FS_UNUSED)
+                                       continue;
+                               i++;
+                               m->opts[i].opt_name = NULL;
+                               m->opts[i].opt_exp_name = NULL;
+                               m->opts[i].opt_action = pm_submenu;
+                               ((struct part_entry *)arg)[i].parts = secondary;
                                ((struct part_entry *)arg)[i].dev_ptr = pm_i;
                                ((struct part_entry *)arg)[i].id = ii;
                                ((struct part_entry *)arg)[i].type = PM_PART;



Home | Main Index | Thread Index | Old Index