|
|
@ -35,16 +35,16 @@ static const char mconf_readme[] = N_( |
|
|
|
"\n" |
|
|
|
"To change any of these features, highlight it with the cursor\n" |
|
|
|
"keys and press <Y> to build it in, <M> to make it a module or\n" |
|
|
|
"<N> to removed it. You may also press the <Space Bar> to cycle\n" |
|
|
|
"through the available options (ie. Y->N->M->Y).\n" |
|
|
|
"<N> to remove it. You may also press the <Space Bar> to cycle\n" |
|
|
|
"through the available options (i.e. Y->N->M->Y).\n" |
|
|
|
"\n" |
|
|
|
"Some additional keyboard hints:\n" |
|
|
|
"\n" |
|
|
|
"Menus\n" |
|
|
|
"----------\n" |
|
|
|
"o Use the Up/Down arrow keys (cursor keys) to highlight the item\n" |
|
|
|
" you wish to change or submenu wish to select and press <Enter>.\n" |
|
|
|
" Submenus are designated by \"--->\".\n" |
|
|
|
"o Use the Up/Down arrow keys (cursor keys) to highlight the item you\n" |
|
|
|
" wish to change or the submenu you wish to select and press <Enter>.\n" |
|
|
|
" Submenus are designated by \"--->\", empty ones by \"----\".\n" |
|
|
|
"\n" |
|
|
|
" Shortcut: Press the option's highlighted letter (hotkey).\n" |
|
|
|
" Pressing a hotkey more than once will sequence\n" |
|
|
@ -61,7 +61,7 @@ static const char mconf_readme[] = N_( |
|
|
|
" there is a delayed response which you may find annoying.\n" |
|
|
|
"\n" |
|
|
|
" Also, the <TAB> and cursor keys will cycle between <Select>,\n" |
|
|
|
" <Exit> and <Help>.\n" |
|
|
|
" <Exit>, <Help>, <Save>, and <Load>.\n" |
|
|
|
"\n" |
|
|
|
"o To get help with an item, use the cursor keys to highlight <Help>\n" |
|
|
|
" and press <ENTER>.\n" |
|
|
@ -101,7 +101,7 @@ static const char mconf_readme[] = N_( |
|
|
|
"Text Box (Help Window)\n" |
|
|
|
"--------\n" |
|
|
|
"o Use the cursor keys to scroll up/down/left/right. The VI editor\n" |
|
|
|
" keys h,j,k,l function here as do <u>, <d>, <SPACE BAR> and <B> for \n" |
|
|
|
" keys h,j,k,l function here as do <u>, <d>, <SPACE BAR> and <B> for\n" |
|
|
|
" those who are familiar with less and lynx.\n" |
|
|
|
"\n" |
|
|
|
"o Press <E>, <X>, <q>, <Enter> or <Esc><Esc> to exit.\n" |
|
|
@ -113,23 +113,21 @@ static const char mconf_readme[] = N_( |
|
|
|
"those who, for various reasons, find it necessary to switch\n" |
|
|
|
"between different configurations.\n" |
|
|
|
"\n" |
|
|
|
"At the end of the main menu you will find two options. One is\n" |
|
|
|
"for saving the current configuration to a file of your choosing.\n" |
|
|
|
"The other option is for loading a previously saved alternate\n" |
|
|
|
"configuration.\n" |
|
|
|
"The <Save> button will let you save the current configuration to\n" |
|
|
|
"a file of your choosing. Use the <Load> button to load a previously\n" |
|
|
|
"saved alternate configuration.\n" |
|
|
|
"\n" |
|
|
|
"Even if you don't use alternate configuration files, but you\n" |
|
|
|
"find during a Menuconfig session that you have completely messed\n" |
|
|
|
"up your settings, you may use the \"Load Alternate...\" option to\n" |
|
|
|
"restore your previously saved settings from \".config\" without\n" |
|
|
|
"restarting Menuconfig.\n" |
|
|
|
"Even if you don't use alternate configuration files, but you find\n" |
|
|
|
"during a Menuconfig session that you have completely messed up your\n" |
|
|
|
"settings, you may use the <Load> button to restore your previously\n" |
|
|
|
"saved settings from \".config\" without restarting Menuconfig.\n" |
|
|
|
"\n" |
|
|
|
"Other information\n" |
|
|
|
"-----------------\n" |
|
|
|
"If you use Menuconfig in an XTERM window make sure you have your\n" |
|
|
|
"$TERM variable set to point to a xterm definition which supports color.\n" |
|
|
|
"Otherwise, Menuconfig will look rather bad. Menuconfig will not\n" |
|
|
|
"display correctly in a RXVT window because rxvt displays only one\n" |
|
|
|
"If you use Menuconfig in an XTERM window, make sure you have your\n" |
|
|
|
"$TERM variable set to point to an xterm definition which supports\n" |
|
|
|
"color. Otherwise, Menuconfig will look rather bad. Menuconfig will\n" |
|
|
|
"not display correctly in an RXVT window because rxvt displays only one\n" |
|
|
|
"intensity of color, bright.\n" |
|
|
|
"\n" |
|
|
|
"Menuconfig will display larger menus on screens or xterms which are\n" |
|
|
@ -144,8 +142,8 @@ static const char mconf_readme[] = N_( |
|
|
|
"\n" |
|
|
|
"Optional personality available\n" |
|
|
|
"------------------------------\n" |
|
|
|
"If you prefer to have all of the options listed in a single menu, rather\n" |
|
|
|
"than the default multimenu hierarchy, run the menuconfig with\n" |
|
|
|
"If you prefer to have all of the options listed in a single menu,\n" |
|
|
|
"rather than the default multimenu hierarchy, run the menuconfig with\n" |
|
|
|
"MENUCONFIG_MODE environment variable set to single_menu. Example:\n" |
|
|
|
"\n" |
|
|
|
"make MENUCONFIG_MODE=single_menu menuconfig\n" |
|
|
@ -168,11 +166,11 @@ static const char mconf_readme[] = N_( |
|
|
|
" mono => selects colors suitable for monochrome displays\n" |
|
|
|
" blackbg => selects a color scheme with black background\n" |
|
|
|
" classic => theme with blue background. The classic look\n" |
|
|
|
" bluetitle => a LCD friendly version of classic. (default)\n" |
|
|
|
" bluetitle => an LCD friendly version of classic. (default)\n" |
|
|
|
"\n"), |
|
|
|
menu_instructions[] = N_( |
|
|
|
"Arrow keys navigate the menu. " |
|
|
|
"<Enter> selects submenus --->. " |
|
|
|
"<Enter> selects submenus ---> (or empty submenus ----). " |
|
|
|
"Highlighted letters are hotkeys. " |
|
|
|
"Pressing <Y> includes, <N> excludes, <M> modularizes features. " |
|
|
|
"Press <Esc><Esc> to exit, <?> for Help, </> for Search. " |
|
|
@ -234,24 +232,24 @@ search_help[] = N_( |
|
|
|
"Symbol: FOO [=m]\n" |
|
|
|
"Type : tristate\n" |
|
|
|
"Prompt: Foo bus is used to drive the bar HW\n" |
|
|
|
" Defined at drivers/pci/Kconfig:47\n" |
|
|
|
" Depends on: X86_LOCAL_APIC && X86_IO_APIC || IA64\n" |
|
|
|
" Location:\n" |
|
|
|
" -> Bus options (PCI, PCMCIA, EISA, ISA)\n" |
|
|
|
" -> PCI support (PCI [=y])\n" |
|
|
|
"(1) -> PCI access mode (<choice> [=y])\n" |
|
|
|
" Defined at drivers/pci/Kconfig:47\n" |
|
|
|
" Depends on: X86_LOCAL_APIC && X86_IO_APIC || IA64\n" |
|
|
|
" Selects: LIBCRC32\n" |
|
|
|
" Selected by: BAR\n" |
|
|
|
" Selected by: BAR [=n]\n" |
|
|
|
"-----------------------------------------------------------------\n" |
|
|
|
"o The line 'Type:' shows the type of the configuration option for\n" |
|
|
|
" this symbol (boolean, tristate, string, ...)\n" |
|
|
|
"o The line 'Prompt:' shows the text used in the menu structure for\n" |
|
|
|
" this symbol\n" |
|
|
|
"o The 'Defined at' line tell at what file / line number the symbol\n" |
|
|
|
"o The 'Defined at' line tells at what file / line number the symbol\n" |
|
|
|
" is defined\n" |
|
|
|
"o The 'Depends on:' line tell what symbols needs to be defined for\n" |
|
|
|
"o The 'Depends on:' line tells what symbols need to be defined for\n" |
|
|
|
" this symbol to be visible in the menu (selectable)\n" |
|
|
|
"o The 'Location:' lines tell where in the menu structure this symbol\n" |
|
|
|
"o The 'Location:' lines tells where in the menu structure this symbol\n" |
|
|
|
" is located\n" |
|
|
|
" A location followed by a [=y] indicates that this is a\n" |
|
|
|
" selectable menu item - and the current value is displayed inside\n" |
|
|
@ -259,9 +257,9 @@ search_help[] = N_( |
|
|
|
" Press the key in the (#) prefix to jump directly to that\n" |
|
|
|
" location. You will be returned to the current search results\n" |
|
|
|
" after exiting this new menu.\n" |
|
|
|
"o The 'Selects:' line tell what symbol will be automatically\n" |
|
|
|
"o The 'Selects:' line tells what symbols will be automatically\n" |
|
|
|
" selected if this symbol is selected (y or m)\n" |
|
|
|
"o The 'Selected by' line tell what symbol has selected this symbol\n" |
|
|
|
"o The 'Selected by' line tells what symbol has selected this symbol\n" |
|
|
|
"\n" |
|
|
|
"Only relevant lines are shown.\n" |
|
|
|
"\n\n" |
|
|
@ -297,7 +295,7 @@ static void set_config_filename(const char *config_filename) |
|
|
|
int size; |
|
|
|
|
|
|
|
size = snprintf(menu_backtitle, sizeof(menu_backtitle), |
|
|
|
"%s - %s", config_filename, rootmenu.prompt->text); |
|
|
|
"%s - %s", config_filename, rootmenu.prompt->text); |
|
|
|
if (size >= sizeof(menu_backtitle)) |
|
|
|
menu_backtitle[sizeof(menu_backtitle)-1] = '\0'; |
|
|
|
set_dialog_backtitle(menu_backtitle); |
|
|
@ -307,6 +305,50 @@ static void set_config_filename(const char *config_filename) |
|
|
|
filename[sizeof(filename)-1] = '\0'; |
|
|
|
} |
|
|
|
|
|
|
|
struct subtitle_part { |
|
|
|
struct list_head entries; |
|
|
|
const char *text; |
|
|
|
}; |
|
|
|
static LIST_HEAD(trail); |
|
|
|
|
|
|
|
static struct subtitle_list *subtitles; |
|
|
|
static void set_subtitle(void) |
|
|
|
{ |
|
|
|
struct subtitle_part *sp; |
|
|
|
struct subtitle_list *pos, *tmp; |
|
|
|
|
|
|
|
for (pos = subtitles; pos != NULL; pos = tmp) { |
|
|
|
tmp = pos->next; |
|
|
|
free(pos); |
|
|
|
} |
|
|
|
|
|
|
|
subtitles = NULL; |
|
|
|
list_for_each_entry(sp, &trail, entries) { |
|
|
|
if (sp->text) { |
|
|
|
if (pos) { |
|
|
|
pos->next = xcalloc(1, sizeof(*pos)); |
|
|
|
pos = pos->next; |
|
|
|
} else { |
|
|
|
subtitles = pos = xcalloc(1, sizeof(*pos)); |
|
|
|
} |
|
|
|
pos->text = sp->text; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
set_dialog_subtitles(subtitles); |
|
|
|
} |
|
|
|
|
|
|
|
static void reset_subtitle(void) |
|
|
|
{ |
|
|
|
struct subtitle_list *pos, *tmp; |
|
|
|
|
|
|
|
for (pos = subtitles; pos != NULL; pos = tmp) { |
|
|
|
tmp = pos->next; |
|
|
|
free(pos); |
|
|
|
} |
|
|
|
subtitles = NULL; |
|
|
|
set_dialog_subtitles(subtitles); |
|
|
|
} |
|
|
|
|
|
|
|
struct search_data { |
|
|
|
struct list_head *head; |
|
|
@ -349,10 +391,12 @@ static void search_conf(void) |
|
|
|
char *dialog_input; |
|
|
|
int dres, vscroll = 0, hscroll = 0; |
|
|
|
bool again; |
|
|
|
struct gstr sttext; |
|
|
|
struct subtitle_part stpart; |
|
|
|
|
|
|
|
title = str_new(); |
|
|
|
str_printf( &title, _("Enter %s (sub)string to search for " |
|
|
|
"(with or without \"%s\")"), CONFIG_, CONFIG_); |
|
|
|
str_printf( &title, _("Enter (sub)string or regexp to search for " |
|
|
|
"(with or without \"%s\")"), CONFIG_); |
|
|
|
|
|
|
|
again: |
|
|
|
dialog_clear(); |
|
|
@ -375,6 +419,11 @@ again: |
|
|
|
if (strncasecmp(dialog_input_result, CONFIG_, strlen(CONFIG_)) == 0) |
|
|
|
dialog_input += strlen(CONFIG_); |
|
|
|
|
|
|
|
sttext = str_new(); |
|
|
|
str_printf(&sttext, "Search (%s)", dialog_input_result); |
|
|
|
stpart.text = str_get(&sttext); |
|
|
|
list_add_tail(&stpart.entries, &trail); |
|
|
|
|
|
|
|
sym_arr = sym_re_search(dialog_input); |
|
|
|
do { |
|
|
|
LIST_HEAD(head); |
|
|
@ -385,8 +434,10 @@ again: |
|
|
|
.targets = targets, |
|
|
|
.keys = keys, |
|
|
|
}; |
|
|
|
struct jump_key *pos, *tmp; |
|
|
|
|
|
|
|
res = get_relations_str(sym_arr, &head); |
|
|
|
set_subtitle(); |
|
|
|
dres = show_textbox_ext(_("Search Results"), (char *) |
|
|
|
str_get(&res), 0, 0, keys, &vscroll, |
|
|
|
&hscroll, &update_text, (void *) |
|
|
@ -398,9 +449,13 @@ again: |
|
|
|
again = true; |
|
|
|
} |
|
|
|
str_free(&res); |
|
|
|
list_for_each_entry_safe(pos, tmp, &head, entries) |
|
|
|
free(pos); |
|
|
|
} while (again); |
|
|
|
free(sym_arr); |
|
|
|
str_free(&title); |
|
|
|
list_del(trail.prev); |
|
|
|
str_free(&sttext); |
|
|
|
} |
|
|
|
|
|
|
|
static void build_conf(struct menu *menu) |
|
|
@ -437,8 +492,9 @@ static void build_conf(struct menu *menu) |
|
|
|
menu->data ? "-->" : "++>", |
|
|
|
indent + 1, ' ', prompt); |
|
|
|
} else |
|
|
|
item_make(" %*c%s --->", indent + 1, ' ', prompt); |
|
|
|
|
|
|
|
item_make(" %*c%s %s", |
|
|
|
indent + 1, ' ', prompt, |
|
|
|
menu_is_empty(menu) ? "----" : "--->"); |
|
|
|
item_set_tag('m'); |
|
|
|
item_set_data(menu); |
|
|
|
if (single_menu_mode && menu->data) |
|
|
@ -569,7 +625,7 @@ static void build_conf(struct menu *menu) |
|
|
|
(sym_has_value(sym) || !sym_is_changable(sym)) ? |
|
|
|
"" : _(" (NEW)")); |
|
|
|
if (menu->prompt->type == P_MENU) { |
|
|
|
item_add_str(" --->"); |
|
|
|
item_add_str(" %s", menu_is_empty(menu) ? "----" : "--->"); |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
@ -585,27 +641,36 @@ static void conf(struct menu *menu, struct menu *active_menu) |
|
|
|
{ |
|
|
|
struct menu *submenu; |
|
|
|
const char *prompt = menu_get_prompt(menu); |
|
|
|
struct subtitle_part stpart; |
|
|
|
struct symbol *sym; |
|
|
|
int res; |
|
|
|
int s_scroll = 0; |
|
|
|
|
|
|
|
if (menu != &rootmenu) |
|
|
|
stpart.text = menu_get_prompt(menu); |
|
|
|
else |
|
|
|
stpart.text = NULL; |
|
|
|
list_add_tail(&stpart.entries, &trail); |
|
|
|
|
|
|
|
while (1) { |
|
|
|
item_reset(); |
|
|
|
current_menu = menu; |
|
|
|
build_conf(menu); |
|
|
|
if (!child_count) |
|
|
|
break; |
|
|
|
set_subtitle(); |
|
|
|
dialog_clear(); |
|
|
|
res = dialog_menu(prompt ? _(prompt) : _("Main Menu"), |
|
|
|
_(menu_instructions), |
|
|
|
active_menu, &s_scroll); |
|
|
|
if (res == 1 || res == KEY_ESC || res == -ERRDISPLAYTOOSMALL) |
|
|
|
break; |
|
|
|
if (!item_activate_selected()) |
|
|
|
continue; |
|
|
|
if (!item_tag()) |
|
|
|
continue; |
|
|
|
|
|
|
|
if (item_count() != 0) { |
|
|
|
if (!item_activate_selected()) |
|
|
|
continue; |
|
|
|
if (!item_tag()) |
|
|
|
continue; |
|
|
|
} |
|
|
|
submenu = item_data(); |
|
|
|
active_menu = item_data(); |
|
|
|
if (submenu) |
|
|
@ -636,13 +701,17 @@ static void conf(struct menu *menu, struct menu *active_menu) |
|
|
|
case 2: |
|
|
|
if (sym) |
|
|
|
show_help(submenu); |
|
|
|
else |
|
|
|
else { |
|
|
|
reset_subtitle(); |
|
|
|
show_helptext(_("README"), _(mconf_readme)); |
|
|
|
} |
|
|
|
break; |
|
|
|
case 3: |
|
|
|
reset_subtitle(); |
|
|
|
conf_save(); |
|
|
|
break; |
|
|
|
case 4: |
|
|
|
reset_subtitle(); |
|
|
|
conf_load(); |
|
|
|
break; |
|
|
|
case 5: |
|
|
@ -675,6 +744,8 @@ static void conf(struct menu *menu, struct menu *active_menu) |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
list_del(trail.prev); |
|
|
|
} |
|
|
|
|
|
|
|
static int show_textbox_ext(const char *title, char *text, int r, int c, int |
|
|
@ -751,7 +822,9 @@ static void conf_choice(struct menu *menu) |
|
|
|
dialog_clear(); |
|
|
|
res = dialog_checklist(prompt ? _(prompt) : _("Main Menu"), |
|
|
|
_(radiolist_instructions), |
|
|
|
15, 70, 6); |
|
|
|
MENUBOX_HEIGTH_MIN, |
|
|
|
MENUBOX_WIDTH_MIN, |
|
|
|
CHECKLIST_HEIGTH_MIN); |
|
|
|
selected = item_activate_selected(); |
|
|
|
switch (res) { |
|
|
|
case 0: |
|
|
@ -887,11 +960,12 @@ static int handle_exit(void) |
|
|
|
int res; |
|
|
|
|
|
|
|
save_and_exit = 1; |
|
|
|
reset_subtitle(); |
|
|
|
dialog_clear(); |
|
|
|
if (conf_get_changed()) |
|
|
|
res = dialog_yesno(NULL, |
|
|
|
_("Do you wish to save your new configuration ?\n" |
|
|
|
"<ESC><ESC> to continue."), |
|
|
|
_("Do you wish to save your new configuration?\n" |
|
|
|
"(Press <ESC><ESC> to continue kernel configuration.)"), |
|
|
|
6, 60); |
|
|
|
else |
|
|
|
res = -1; |
|
|
@ -966,4 +1040,3 @@ int main(int ac, char **av) |
|
|
|
|
|
|
|
return res; |
|
|
|
} |
|
|
|
|
|
|
|