diff options
author | jkh <jkh@FreeBSD.org> | 1999-12-14 04:25:29 +0000 |
---|---|---|
committer | jkh <jkh@FreeBSD.org> | 1999-12-14 04:25:29 +0000 |
commit | d3944eb60a18bfd5f8b4b6ff033a61a20f2383cc (patch) | |
tree | e8c2e2130b60892a8d69589245c55613e2ca6edf /usr.sbin/sysinstall/index.c | |
parent | 796518d06842cbc05ce0994ade4027837c42cec0 (diff) | |
download | FreeBSD-src-d3944eb60a18bfd5f8b4b6ff033a61a20f2383cc.zip FreeBSD-src-d3944eb60a18bfd5f8b4b6ff033a61a20f2383cc.tar.gz |
Completely rip-out and redesign sysinstall's refresh model as well
as redoing all the menus to have proper, or at least non-hallucinogenic,
keyboard accelerators.
This requires my recent update to libdialog to work properly and will
probably also exhibit some other "interesting" behavior while the last
few missing screen clears are found (which is why I'm not going to MFC
immediately). At least now, however, sysinstall does not gratuitously
redraw random screens at the drop of a hat and drive serial console
installers out of their minds.
Diffstat (limited to 'usr.sbin/sysinstall/index.c')
-rw-r--r-- | usr.sbin/sysinstall/index.c | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/usr.sbin/sysinstall/index.c b/usr.sbin/sysinstall/index.c index cc2193c..034e042 100644 --- a/usr.sbin/sysinstall/index.c +++ b/usr.sbin/sysinstall/index.c @@ -480,8 +480,6 @@ pkg_fire(dialogMenuItem *self) msgInfo("Added %s to selection list", kp->name); } else if (ie->depc == 0) { - WINDOW *save = savescr(); - if (!msgYesNo("Do you really want to delete %s from the system?", kp->name)) { if (vsystem("pkg_delete %s %s", isDebug() ? "-v" : "", kp->name)) { msgConfirm("Warning: pkg_delete of %s failed.\n Check debug output for details.", kp->name); @@ -491,7 +489,6 @@ pkg_fire(dialogMenuItem *self) index_recorddeps(FALSE, lists->root, ie); } } - restorescr(save); } else msgConfirm("Warning: Package %s is needed by\n %d other installed package%s.", @@ -537,16 +534,15 @@ index_menu(PkgNodePtr root, PkgNodePtr top, PkgNodePtr plist, int *pos, int *scr dialogMenuItem *nitems; Boolean hasPackages; WINDOW *w; - + lists.root = root; lists.top = top; lists.plist = plist; hasPackages = FALSE; nitems = NULL; - - w = savescr(); n = maxname = 0; + /* Figure out if this menu is full of "leaves" or "branches" */ for (kp = top->kids; kp && kp->name; kp = kp->next) { int len; @@ -560,10 +556,10 @@ index_menu(PkgNodePtr root, PkgNodePtr top, PkgNodePtr plist, int *pos, int *scr } if (!n && plist) { msgConfirm("The %s menu is empty.", top->name); - restorescr(w); return DITEM_LEAVE_MENU; } + w = savescr(); while (1) { n = 0; curr = max = 0; @@ -707,20 +703,27 @@ int index_initialize(char *path) { FILE *fp; + WINDOW *w = NULL; if (!index_initted) { + w = savescr(); + dialog_clear_norefresh(); + /* Got any media? */ - if (!mediaVerify()) + if (!mediaVerify()) { + restorescr(w); return DITEM_FAILURE; + } /* Does it move when you kick it? */ - if (!mediaDevice->init(mediaDevice)) + if (!mediaDevice->init(mediaDevice)) { + restorescr(w); return DITEM_FAILURE; + } msgNotify("Attempting to fetch %s file from selected media.", path); fp = mediaDevice->get(mediaDevice, path, TRUE); if (!fp) { - dialog_clear_norefresh(); msgConfirm("Unable to get packages/INDEX file from selected media.\n" "This may be because the packages collection is not available at\n" "on the distribution media you've chosen (most likely an FTP site\n" @@ -729,7 +732,8 @@ index_initialize(char *path) "carry the packages collection, then we recommend either a CD\n" "distribution or the master distribution on ftp.freebsd.org."); mediaDevice->shutdown(mediaDevice); - return DITEM_FAILURE | DITEM_RESTORE; + restorescr(w); + return DITEM_FAILURE; } msgNotify("Located INDEX, now reading package data from it..."); index_init(&Top, &Plist); @@ -737,11 +741,13 @@ index_initialize(char *path) msgConfirm("I/O or format error on packages/INDEX file.\n" "Please verify media (or path to media) and try again."); fclose(fp); - return DITEM_FAILURE | DITEM_RESTORE; + restorescr(w); + return DITEM_FAILURE; } fclose(fp); index_sort(&Top); index_initted = TRUE; } - return DITEM_SUCCESS | DITEM_RESTORE; + restorescr(w); + return DITEM_SUCCESS; } |