[PATCH] fix menuconfig choice help

From: Mitch Adair (mitch@theneteffect.com)
Date: Fri Mar 21 2003 - 17:16:48 EST


Menuconfig currently doesn't show the help texts that go along with config
options inside a choice block. (A good example is the "Processor family"
submenu - none of the per-processor help texts show up.)

The following patch fixes this - menuconfig now shows the help text for
the config option under the cursor (not necessarily the selected item.)

        M

diff -urN linux-2.5.65/scripts/kconfig/mconf.c linux-2.5.65-mconf/scripts/kconfig/mconf.c
--- linux-2.5.65/scripts/kconfig/mconf.c Fri Mar 21 13:25:48 2003
+++ linux-2.5.65-mconf/scripts/kconfig/mconf.c Fri Mar 21 15:39:45 2003
@@ -627,7 +627,8 @@
                         sym_set_tristate_value(menu->sym, yes);
                         return;
                 case 1:
- show_help(menu);
+ if (sscanf(input_buf, "%p", &child) == 1)
+ show_help(child);
                         break;
                 case 255:
                         return;
diff -urN linux-2.5.65/scripts/lxdialog/checklist.c linux-2.5.65-mconf/scripts/lxdialog/checklist.c
--- linux-2.5.65/scripts/lxdialog/checklist.c Tue Mar 4 21:29:18 2003
+++ linux-2.5.65-mconf/scripts/lxdialog/checklist.c Fri Mar 21 13:54:40 2003
@@ -302,6 +302,21 @@
         case 'H':
         case 'h':
         case '?':
+ if (!status[scroll + choice]) {
+ for (i = 0; i < item_no; i++)
+ status[i] = 0;
+ status[scroll + choice] = 1;
+ for (i = 0; i < max_choice; i++)
+ print_item (list, items[(scroll + i) * 3 + 1],
+ status[scroll + i], i, i == choice);
+ }
+ wnoutrefresh (list);
+ wrefresh (dialog);
+
+ for (i = 0; i < item_no; i++) {
+ if (status[i])
+ fprintf (stderr, "%s", items[i * 3]);
+ }
             delwin (dialog);
             free (status);
             return 1;
@@ -318,36 +333,34 @@
         case 's':
         case ' ':
         case '\n':
- if (!button) {
- if (flag == FLAG_CHECK) {
- status[scroll + choice] = !status[scroll + choice];
- wmove (list, choice, check_x);
- wattrset (list, check_selected_attr);
- wprintw (list, "[%c]", status[scroll + choice] ? 'X' : ' ');
- } else {
- if (!status[scroll + choice]) {
- for (i = 0; i < item_no; i++)
- status[i] = 0;
- status[scroll + choice] = 1;
- for (i = 0; i < max_choice; i++)
- print_item (list, items[(scroll + i) * 3 + 1],
- status[scroll + i], i, i == choice);
- }
+ if (flag == FLAG_CHECK) {
+ status[scroll + choice] = !status[scroll + choice];
+ wmove (list, choice, check_x);
+ wattrset (list, check_selected_attr);
+ wprintw (list, "[%c]", status[scroll + choice] ? 'X' : ' ');
+ } else {
+ if (!status[scroll + choice]) {
+ for (i = 0; i < item_no; i++)
+ status[i] = 0;
+ status[scroll + choice] = 1;
+ for (i = 0; i < max_choice; i++)
+ print_item (list, items[(scroll + i) * 3 + 1],
+ status[scroll + i], i, i == choice);
                 }
- wnoutrefresh (list);
- wrefresh (dialog);
-
- for (i = 0; i < item_no; i++) {
- if (status[i]) {
- if (flag == FLAG_CHECK) {
- fprintf (stderr, "\"%s\" ", items[i * 3]);
- } else {
- fprintf (stderr, "%s", items[i * 3]);
- }
+ }
+ wnoutrefresh (list);
+ wrefresh (dialog);
 
+ for (i = 0; i < item_no; i++) {
+ if (status[i]) {
+ if (flag == FLAG_CHECK) {
+ fprintf (stderr, "\"%s\" ", items[i * 3]);
+ } else {
+ fprintf (stderr, "%s", items[i * 3]);
                     }
+
                 }
- }
+ }
             delwin (dialog);
             free (status);
             return button;
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Sun Mar 23 2003 - 22:00:39 EST