1/* $NetBSD: menus.mi,v 1.29 2023/12/17 18:46:42 martin Exp $ */ 2 3/*- 4 * Copyright (c) 2003 The NetBSD Foundation, Inc. 5 * All rights reserved. 6 * 7 * This code is derived from software contributed to The NetBSD Foundation 8 * by David Laight. 9 * 10 * Redistribution and use in source and binary forms, with or without 11 * modification, are permitted provided that the following conditions 12 * are met: 13 * 1. Redistributions of source code must retain the above copyright 14 * notice, this list of conditions and the following disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 * POSSIBILITY OF SUCH DAMAGE. 30 */ 31 32/* 33 * Menu system definitions -- machine and language independent 34 * 35 * Some menus may be called directly in the code rather than via the 36 * menu system. 37 * 38 * This file must be first in the sed command line. 39 * 40 */ 41 42{ 43#include <stdio.h> 44#include <time.h> 45#include <curses.h> 46#include "defs.h" 47#include "md.h" 48#include "msg_defs.h" 49#include "menu_defs.h" 50 51static menudesc menu_def[]; 52 53static void 54expand_option_text(menudesc *menu, void *arg, int sel) 55{ 56 arg_replace *ar = arg; 57 struct menu_ent *opt = &menu->opts[sel]; 58 59 if (menu->opts[sel].opt_exp_name) 60 return; /* has already been expanded */ 61 62 opt->opt_exp_name = 63 str_arg_subst(MSG_XLAT(opt->opt_name), ar->argc, ar->argv); 64} 65 66void 67expand_all_option_texts(menudesc *menu, void *arg) 68{ 69 arg_replace *ar = arg; 70 const char *title; 71 int i; 72 73 if (menu->title != NULL && menu->exp_title == NULL) { 74 title = MSG_XLAT(menu->title); 75 if (needs_expanding(title, ar->argc)) { 76 menu->exp_title = str_arg_subst(title, 77 ar->argc, ar->argv); 78 } 79 } 80 for (i = 0; i < menu->numopts; i++) { 81 const char *t = MSG_XLAT(menu->opts[i].opt_name); 82 83 if (t == NULL) continue; 84 85 if (needs_expanding(t, ar->argc)) 86 expand_option_text(menu, arg, i); 87 } 88} 89 90/* 91 * Re-create the menu window with heigh/width updated to current state. 92 */ 93void 94resize_menu_height(menudesc *m) 95{ 96 97 if (m->mw == NULL) 98 return; 99 100 wclear(m->mw); 101 if (m->sv_mw) { 102 overwrite(m->sv_mw, m->mw); 103 delwin(m->sv_mw); 104 m->sv_mw = NULL; 105 } 106 wnoutrefresh(m->mw); 107 delwin(m->mw); 108 m->mw = NULL; 109} 110 111static void 112src_legend(menudesc *menu, const char *legend, const char *text) 113{ 114 wprintw(menu->mw, "%-35s %.50s", MSG_XLAT(legend), MSG_XLAT(text)); 115} 116 117static void 118src_prompt(const char *prompt, char *buf, size_t size) 119{ 120 msg_prompt_win(prompt, -1, 12, 0, 0, buf, buf, size); 121} 122 123static void 124remove_sub_menu(int menuID) 125{ 126 127 for (size_t i = 0; i < DYN_MENU_START; i++) { 128 for (int j = 0; j < menu_def[i].numopts; j++) { 129 if ((menu_def[i].opts[j].opt_flags & OPT_SUB) 130 && menu_def[i].opts[j].opt_menu == menuID) { 131 132 for (int k = j + 1; k < menu_def[i].numopts; 133 k++) { 134 menu_def[i].opts[k-1] = 135 menu_def[i].opts[k]; 136 } 137 menu_def[i].numopts--; 138 return; 139 140 } 141 } 142 } 143} 144 145#ifndef NO_PARTMAN 146static void 147remove_menu_option(int menuID, const char *option) 148{ 149 150 for (int j = 0; j < menu_def[menuID].numopts; j++) { 151 if (menu_def[menuID].opts[j].opt_name == option) { 152 for (int k = j + 1; k < menu_def[menuID].numopts; 153 k++) { 154 menu_def[menuID].opts[k-1] = 155 menu_def[menuID].opts[k]; 156 } 157 menu_def[menuID].numopts--; 158 return; 159 160 } 161 } 162} 163#endif 164 165void 166remove_color_options() 167{ 168 /* 169 * Current terminal type does not support colors, so remove all 170 * menu entries (actually that is: Utils/Color Scheme) that do not 171 * make any sense in this case. 172 */ 173 remove_sub_menu(MENU_colors); 174} 175 176#ifndef NO_PARTMAN 177void 178remove_raid_options() 179{ 180 /* 181 * No raidframe available, remove the following menu entries: 182 */ 183 remove_menu_option(MENU_pmdiskentry, MSG_fmtasraid); 184 remove_menu_option(MENU_pmpartentry, MSG_fmtasraid); 185} 186 187void 188remove_lvm_options() 189{ 190 /* 191 * No LVM available, remove the following menu entries: 192 */ 193 remove_menu_option(MENU_pmdiskentry, MSG_fmtaslvm); 194 remove_menu_option(MENU_pmpartentry, MSG_fmtaslvm); 195} 196 197void 198remove_cgd_options() 199{ 200 /* 201 * No CGD available, remove the following menu entries: 202 */ 203 remove_menu_option(MENU_pmdiskentry, MSG_encrypt); 204 remove_menu_option(MENU_pmpartentry, MSG_encrypt); 205} 206#endif 207 208} 209 210default y=12, no exit, scrollable; 211 212allow dynamic menus; 213allow dynamic messages; 214allow expand; 215 216error action { 217 fprintf (stderr, "Could not initialize menu system, please check " 218 "your terminal type.\n"); 219 exit(4); 220}; 221 222/* 223 * Called with arg = struct single_part_fs_edit* 224 */ 225menu mountoptions, title MSG_toggle, y=5, x=30, exitstring MSG_unchanged; 226 /* 227 * XXX - enable / disable options depending on FS type in 228 * display action 229 */ 230 option "log", exit, action 231 { struct single_part_fs_edit *edit = arg; 232 edit->pset->infos[edit->index].mountflags ^= PUIMNT_LOG; }; 233 option "async", exit, action 234 { struct single_part_fs_edit *edit = arg; 235 edit->pset->infos[edit->index].mountflags ^= PUIMNT_ASYNC; }; 236 option "noatime", exit, action 237 { struct single_part_fs_edit *edit = arg; 238 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NOATIME; }; 239 option "nodev", exit, action 240 { struct single_part_fs_edit *edit = arg; 241 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NODEV; }; 242 option "nodevmtime", exit, action 243 { struct single_part_fs_edit *edit = arg; 244 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NODEVMTIME; }; 245 option "noexec", exit, action 246 { struct single_part_fs_edit *edit = arg; 247 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NOEXEC; }; 248 option "nosuid", exit, action 249 { struct single_part_fs_edit *edit = arg; 250 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NOSUID; }; 251 option "noauto", exit, action 252 { struct single_part_fs_edit *edit = arg; 253 edit->pset->infos[edit->index].mountflags ^= PUIMNT_NOAUTO; }; 254 255menu netbsd, title MSG_NetBSD_VERSION_Install_System, y=-1, 256 exit, exitstring MSG_Exit_Install_System; 257 display action { toplevel(); }; 258 option MSG_Install_NetBSD_to_hard_disk, 259 action { do_install(); }; 260 option MSG_Upgrade_NetBSD_on_a_hard_disk, 261 action { do_upgrade(); }; 262 option MSG_Re_install_sets_or_install_additional_sets, 263 action { do_reinstall_sets(); }; 264 option MSG_Reboot_the_computer, exit, 265 action (endwin) { system("/sbin/reboot -q"); }; 266 option MSG_Utility_menu, sub menu utility; 267 option MSG_Config_menu, action { do_configmenu(NULL); }; 268 269menu utility, title MSG_NetBSD_VERSION_Utilities, exit, 270 exitstring MSG_exit_menu_generic; 271 display action { toplevel(); }; 272 option MSG_Run_bin_sh, 273 action (endwin) { system("/bin/sh -i -E"); }; 274 option MSG_Set_timezone, 275 action { set_timezone(); }; 276 option MSG_Configure_network, 277 action { 278 extern int network_up; 279 network_up = 0; 280 config_network(1); 281 }; 282 option MSG_Partition_a_disk, 283 action { 284#ifndef NO_PARTMAN 285 partman_go = 1; 286 partman(NULL); 287#endif 288 }; 289 option MSG_Logging_functions, action { do_logging(); }; 290 option MSG_Color_scheme, sub menu colors; 291 option MSG_Halt_the_system, exit, 292 action (endwin) { system("/sbin/halt -q"); }; 293 294menu colors, title MSG_Color_scheme, exit, 295 exitstring MSG_exit_menu_generic; 296 option MSG_White_on_black, action { do_coloring(COLOR_WHITE,COLOR_BLACK); }; 297 option MSG_Black_on_white, action { do_coloring(COLOR_BLACK,COLOR_WHITE); }; 298 option MSG_White_on_blue, action { do_coloring(COLOR_WHITE,COLOR_BLUE); }; 299 option MSG_Green_on_black, action { do_coloring(COLOR_GREEN,COLOR_BLACK); }; 300 301 302menu yesno, y=-10; 303 display action { arg_rv *p = arg; 304 menu->title = p->arg ? p->arg : MSG_yes_or_no; }; 305 option MSG_Yes, exit, action { ((arg_rv*)arg)->rv = 1; }; 306 option MSG_No, exit, action { ((arg_rv*)arg)->rv = 0; }; 307 308menu noyes, y=-10; 309 display action { arg_rv *p = arg; 310 menu->title = p->arg ? p->arg : MSG_yes_or_no; }; 311 option MSG_No, exit, action { ((arg_rv*)arg)->rv = 0; }; 312 option MSG_Yes, exit, action { ((arg_rv*)arg)->rv = 1; }; 313 314menu ok, no shortcut, y=-10; 315 display action { menu->title = arg; }; 316 option MSG_Hit_enter_to_continue, exit; 317 318menu sizechoice, sub menu, y=0, title MSG_Choose_your_size_specifier; 319 display action { 320 if (sizemult == pm->current_cylsize) 321 menu->cursel = 2; 322 else if (sizemult == 1) 323 menu->cursel = 3; 324 else if (sizemult == (GIG/pm->sectorsize)) 325 menu->cursel = 0; 326 else 327 menu->cursel = 1; }; 328 option MSG_Gigabytes, exit, action 329 { set_sizemult(GIG, pm->sectorsize); }; 330 option MSG_Megabytes, exit, action 331 { set_sizemult(MEG, pm->sectorsize); }; 332 option MSG_Cylinders, exit, action 333 { set_sizemult(pm->current_cylsize*pm->sectorsize, pm->sectorsize); }; 334 option MSG_Sectors, exit, action 335 { set_sizemult(pm->sectorsize, pm->sectorsize); }; 336 337menu ptnsize_replace_existing_partition, sub menu, y=0, 338 title MSG_ptnsize_replace_existing; 339 display action { menu->cursel = 1; }; 340 option MSG_Yes, exit, action { *((int*)arg) = 1; }; 341 option MSG_cancel, exit, action { *((int*)arg) = 0; }; 342 343menu distmedium, title MSG_Select_medium, y=-5; 344 option MSG_cdrom, exit, action { *(int *)arg = get_via_cdrom(); }; 345 option MSG_http, exit, action { *(int *)arg = get_via_ftp(XFER_HTTP); }; 346 option MSG_ftp, exit, action { *(int *)arg = get_via_ftp(XFER_FTP); }; 347 option MSG_nfs, exit, action { *(int *)arg = get_via_nfs(); }; 348 option MSG_floppy, exit, action { *(int *)arg = get_via_floppy(); }; 349 option MSG_local_fs, exit, action { *(int *)arg = get_via_localfs(); }; 350 option MSG_local_dir, exit, action { *(int *)arg = get_via_localdir();}; 351 option MSG_Skip_set, exit, action { *(int *)arg = SET_SKIP; }; 352 option MSG_Skip_group,exit, action { *(int *)arg = SET_SKIP_GROUP; }; 353 option MSG_Abandon, exit, action { *(int *)arg = SET_ABANDON; }; 354 355menu distset, title MSG_Select_your_distribution, exit, 356 no default exit, exitstring MSG_Abandon; 357 display action { msg_display (MSG_distset); }; 358 option MSG_Full_installation, exit, action { *(int *)arg = 1; init_set_status(0); }; 359 option MSG_Full_installation_nox, exit, action { *(int *)arg = 1; init_set_status(SFLAG_NOX); }; 360 option MSG_Minimal_installation, exit, action { *(int *)arg = 1; init_set_status(SFLAG_MINIMAL); }; 361 option MSG_Custom_installation, exit, action { *(int *)arg = 1; init_set_status(SFLAG_MINIMAL); customise_sets(); }; 362 363menu ftpsource, y=-4, x=0, w=70, no box, no clear, 364 exitstring MSG_Get_Distribution; 365 display action { 366 msg_display_subst(MSG_ftpsource, 2, "." SETS_TAR_SUFF, 367 url_proto((uintptr_t)((arg_rv*)arg)->arg)); 368 }; 369 option {src_legend(menu, MSG_Host, ftp.xfer_host[ 370 XFER_HOST((uintptr_t)((arg_rv*)arg)->arg)]);}, 371 action { src_prompt(MSG_Host, ftp.xfer_host[ 372 XFER_HOST((uintptr_t)((arg_rv*)arg)->arg)], 373 sizeof ftp.xfer_host[XFER_HOST( 374 (uintptr_t)((arg_rv*)arg)->arg)]); }; 375 option {src_legend(menu, MSG_Base_dir, ftp.dir);}, 376 action { src_prompt(MSG_Base_dir, ftp.dir, sizeof ftp.dir); }; 377 option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);}, 378 action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); }; 379 option {src_legend(menu, MSG_Set_dir_src, set_dir_src);}, 380 action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); }; 381 option {src_legend(menu, MSG_Dist_postfix, dist_postfix);}, 382 action { src_prompt(MSG_Dist_postfix, dist_postfix, sizeof dist_postfix); }; 383 option {src_legend(menu, MSG_User, ftp.user);}, 384 action { src_prompt(MSG_User, ftp.user, sizeof ftp.user); 385 ftp.pass[0] = 0; 386 }; 387 option {src_legend(menu, MSG_Password, 388 strcmp(ftp.user, "ftp") == 0 || ftp.pass[0] == 0 389 ? ftp.pass : msg_string(MSG_hidden));}, 390 action { if (strcmp(ftp.user, "ftp") == 0) 391 src_prompt(MSG_email, ftp.pass, sizeof ftp.pass); 392 else { 393 msg_prompt_noecho(MSG_Password, "", 394 ftp.pass, sizeof ftp.pass); 395 } 396 }; 397 option {src_legend(menu, MSG_Proxy, ftp.proxy);}, 398 action { src_prompt(MSG_Proxy, ftp.proxy, sizeof ftp.proxy); 399 if (strcmp(ftp.proxy, "") == 0) { 400 unsetenv("ftp_proxy"); 401 unsetenv("http_proxy"); 402 } else { 403 setenv("ftp_proxy", ftp.proxy, 1); 404 setenv("http_proxy", ftp.proxy, 1); 405 } 406 }; 407 option {src_legend(menu, MSG_Xfer_dir, xfer_dir);}, 408 action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); }; 409 option {src_legend(menu, MSG_delete_xfer_file, 410 clean_xfer_dir ? MSG_Yes : MSG_No);}, 411 action {clean_xfer_dir = ask_yesno(MSG_delete_xfer_file); }; 412 option MSG_Configure_network, 413 action { 414 extern int network_up; 415 network_up = 0; 416 config_network(1); 417 }; 418 option MSG_exit_menu_generic, exit, action { ((arg_rv*)arg)->rv = SET_RETRY; }; 419 420 421menu nfssource, y=-4, x=0, w=70, no box, no clear, 422 exitstring MSG_Get_Distribution; 423 display action { const char suff[] = "." SETS_TAR_SUFF; 424 msg_display_subst(MSG_nfssource, 1, &suff); }; 425 option {src_legend(menu, MSG_Host, nfs_host);}, 426 action { src_prompt(MSG_Host, nfs_host, sizeof nfs_host); }; 427 option {src_legend(menu, MSG_Base_dir, nfs_dir);}, 428 action { src_prompt(MSG_Base_dir, nfs_dir, sizeof nfs_dir); }; 429 option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);}, 430 action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); }; 431 option {src_legend(menu, MSG_Set_dir_src, set_dir_src);}, 432 action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); }; 433 option {src_legend(menu, MSG_Dist_postfix, dist_postfix);}, 434 action { src_prompt(MSG_Dist_postfix, dist_postfix, sizeof dist_postfix); }; 435 option MSG_Configure_network, 436 action { 437 extern int network_up; 438 network_up = 0; 439 config_network(1); 440 }; 441 option MSG_exit_menu_generic, exit, action { *((int*)arg) = SET_RETRY; }; 442 443menu fdremount, title MSG_What_do_you_want_to_do; 444 option MSG_Try_again, exit, action { *(int *)arg = SET_CONTINUE; }; 445 option MSG_Set_finished, exit, action { *(int *)arg = SET_OK; }; 446 option MSG_Abort_fetch, exit, action { *(int *)arg = SET_RETRY; }; 447 448menu fdok, title MSG_What_do_you_want_to_do; 449 option MSG_OK, exit, action { *(int *)arg = SET_CONTINUE; }; 450 option MSG_Set_finished, exit, action { *(int *)arg = SET_OK; }; 451 option MSG_Abort_fetch, exit, action { *(int *)arg = SET_RETRY; }; 452 453menu fd_type, title MSG_fd_type, y=16; 454 option "msdos", exit, action { fd_type = "msdos"; }; 455 option "ffs", exit, action { fd_type = "ffs"; }; 456.if ADOS_FLOPPY 457 option "ados", exit, action { fd_type = "ados"; }; 458.endif 459 460menu floppysource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue; 461 display action { msg_display(MSG_floppysource); }; 462 option {src_legend(menu, MSG_Device, fd_dev);}, 463 action { src_prompt(MSG_dev, fd_dev, sizeof fd_dev); }; 464 option {src_legend(menu, MSG_fd_type, fd_type);}, sub menu fd_type; 465 option {src_legend(menu, MSG_Xfer_dir, xfer_dir);}, 466 action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); }; 467 option {src_legend(menu, MSG_delete_xfer_file, 468 clean_xfer_dir ? MSG_Yes : MSG_No);}, 469 action {clean_xfer_dir = ask_yesno(MSG_delete_xfer_file); }; 470 option MSG_exit_menu_generic, exit, action { *((int*)arg) = SET_RETRY; }; 471 472menu cdromsource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue; 473 display action { const char suff[] = "." SETS_TAR_SUFF; 474 msg_display_add_subst(MSG_cdromsource, 1, &suff); }; 475 option {src_legend(menu, MSG_Device, cdrom_dev);}, 476 action { src_prompt(MSG_dev, cdrom_dev, sizeof cdrom_dev); }; 477 option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);}, 478 action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); }; 479 option {src_legend(menu, MSG_Set_dir_src, set_dir_src);}, 480 action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); }; 481 option {src_legend(menu, MSG_Dist_postfix, dist_postfix);}, 482 action { src_prompt(MSG_Dist_postfix, dist_postfix, sizeof dist_postfix); }; 483 option MSG_abort_install, exit, action { *((int*)arg) = SET_ABANDON; }; 484 option MSG_source_sel_retry, exit, action { *((int*)arg) = SET_RETRY; }; 485 486menu localfssource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue; 487 display action { const char suff[] = "." SETS_TAR_SUFF; 488 msg_display_subst(MSG_localfssource, 1, &suff); }; 489 option {src_legend(menu, MSG_Device, localfs_dev);}, 490 action { src_prompt(MSG_dev, localfs_dev, sizeof localfs_dev);}; 491 option {src_legend(menu, MSG_File_system, localfs_fs);}, 492 action { src_prompt(MSG_filesys, localfs_fs, sizeof localfs_fs); }; 493 option {src_legend(menu, MSG_Base_dir, localfs_dir);}, 494 action { src_prompt(MSG_Base_dir, localfs_dir, sizeof localfs_dir);}; 495 option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);}, 496 action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); }; 497 option {src_legend(menu, MSG_Set_dir_src, set_dir_src);}, 498 action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); }; 499 option {src_legend(menu, MSG_Dist_postfix, dist_postfix);}, 500 action { src_prompt(MSG_Dist_postfix, dist_postfix, sizeof dist_postfix); }; 501 option MSG_exit_menu_generic, exit, action { *((int*)arg) = SET_RETRY; }; 502 503menu localdirsource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue; 504 display action { const char suff[] = "." SETS_TAR_SUFF; 505 msg_display_subst(MSG_localdir, 1, &suff); }; 506 option {src_legend(menu, MSG_Base_dir, localfs_dir);}, 507 action { src_prompt(MSG_Base_dir, localfs_dir, 60); }; 508 option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);}, 509 action { src_prompt(MSG_Set_dir_bin, set_dir_bin, 60); }; 510 option {src_legend(menu, MSG_Set_dir_src, set_dir_src);}, 511 action { src_prompt(MSG_Set_dir_src, set_dir_src, 60); }; 512 option {src_legend(menu, MSG_Dist_postfix, dist_postfix);}, 513 action { src_prompt(MSG_Dist_postfix, dist_postfix, 60); }; 514 option MSG_exit_menu_generic, exit, action { *((int*)arg) = SET_RETRY; }; 515 516menu namesrv6, title MSG_Select_DNS_server; 517 option "google-public-dns-a.google.com (IPv4)", exit, action 518 { 519#ifdef INET6 520 strlcpy(net_namesvr, "8.8.8.8", 521 sizeof(net_namesvr)); 522 *((int*)arg) = 1; 523#else 524 *((int*)arg) = 0; 525#endif 526 }; 527 option "google-public-dns-b.google.com (IPv4)", exit, action 528 { 529#ifdef INET6 530 strlcpy(net_namesvr, "8.8.4.4", 531 sizeof(net_namesvr)); 532 *((int*)arg) = 1; 533#else 534 *((int*)arg) = 0; 535#endif 536 }; 537 option "google-public-dns-a.google.com (IPv6)", exit, action 538 { 539#ifdef INET6 540 strlcpy(net_namesvr, "2001:4860:4860::8888", 541 sizeof(net_namesvr)); 542 *((int*)arg) = 1; 543#else 544 *((int*)arg) = 0; 545#endif 546 }; 547 option "google-public-dns-b.google.com (IPv6)", exit, action 548 { 549#ifdef INET6 550 strlcpy(net_namesvr, "2001:4860:4860::8844", 551 sizeof(net_namesvr)); 552 *((int*)arg) = 1; 553#else 554 *((int*)arg) = 0; 555#endif 556 }; 557 option MSG_other, exit, action 558 { *((int*)arg) = 0; }; 559 560menu rootsh, title MSG_Root_shell, no clear; 561 option "/bin/sh", exit, action {*(const char **)arg = "/bin/sh";}; 562 option "/bin/ksh", exit, action {*(const char **)arg = "/bin/ksh";}; 563 option "/bin/csh", exit, action {*(const char **)arg = "/bin/csh";}; 564 565menu zeroconf, title "Zeroconf", no clear; 566 option "run mdnsd only", exit, action {*(const char **)arg = "mdnsd";}; 567 option "run mdnsd and resolve local names", exit, action {*(const char **) arg = "mdnsd+nsswitch";}; 568 option "do not run mdnsd", exit, action {*(const char **)arg = "No";}; 569 570menu binpkg, y=-4, x=0, w=70, no box, no clear, 571 exitstring MSG_Install_pkgin; 572 display action { msg_display(MSG_pkgpath); }; 573 option {src_legend(menu, MSG_Host, 574 pkg.xfer_host[XFER_HOST(pkg.xfer)]);}, 575 action { src_prompt(MSG_Host, 576 pkg.xfer_host[XFER_HOST(pkg.xfer)], 577 sizeof pkg.xfer_host[XFER_HOST(pkg.xfer)]); }; 578 option {src_legend(menu, MSG_Base_dir, pkg.dir);}, 579 action { src_prompt(MSG_Base_dir, pkg.dir, sizeof pkg.dir); }; 580 option {src_legend(menu, MSG_Pkg_dir, pkg_dir);}, 581 action { src_prompt(MSG_Pkg_dir, pkg_dir, sizeof pkg_dir); }; 582 option {src_legend(menu, MSG_User, pkg.user);}, 583 action { src_prompt(MSG_User, pkg.user, sizeof pkg.user); 584 pkg.pass[0] = 0; 585 }; 586 option {src_legend(menu, MSG_Password, 587 strcmp(pkg.user, "ftp") == 0 || pkg.pass[0] == 0 588 ? pkg.pass : msg_string(MSG_hidden));}, 589 action { if (strcmp(pkg.user, "ftp") == 0) 590 src_prompt(MSG_email, pkg.pass, sizeof pkg.pass); 591 else { 592 msg_prompt_noecho(MSG_Password, "", 593 pkg.pass, sizeof pkg.pass); 594 } 595 }; 596 option {src_legend(menu, MSG_Proxy, pkg.proxy);}, 597 action { src_prompt(MSG_Proxy, pkg.proxy, sizeof pkg.proxy); 598 if (strcmp(pkg.proxy, "") == 0) { 599 unsetenv("ftp_proxy"); 600 unsetenv("http_proxy"); 601 } else { 602 setenv("ftp_proxy", pkg.proxy, 1); 603 setenv("http_proxy", pkg.proxy, 1); 604 } 605 }; 606 option {src_legend(menu, "Additional packages", (char*)(((arg_rv*)arg)->arg)); }, /*TODO*/ 607 action { src_prompt("Additional packages", (char*)(((arg_rv*)arg)->arg), 608 sizeof(char) * STRSIZE); }; 609 option MSG_Configure_network, 610 action { 611 extern int network_up; 612 network_up = 0; 613 config_network(1); 614 mnt_net_config(); 615 }; 616 option {src_legend(menu, MSG_transfer_method, url_proto(pkg.xfer));}, 617 action { pkg.xfer = (pkg.xfer+1) % (XFER_MAX+1); }; 618 option MSG_quit_pkgs_install, exit, action { ((arg_rv*)arg)->rv = SET_SKIP; }; 619 620menu pkgsrc, y=-4, x=0, w=70, no box, no clear, 621 exit, exitstring MSG_Install_pkgsrc; 622 display action { msg_display(MSG_pkgsrc); }; 623 option {src_legend(menu, MSG_Host, pkgsrc.xfer_host[ 624 XFER_HOST(pkgsrc.xfer)]);}, 625 action { src_prompt(MSG_Host, 626 pkgsrc.xfer_host[XFER_HOST(pkgsrc.xfer)], 627 sizeof pkgsrc.xfer_host[XFER_HOST(pkgsrc.xfer)]); }; 628 option {src_legend(menu, MSG_Pkgsrc_dir, pkgsrc_dir);}, 629 action { src_prompt(MSG_Pkgsrc_dir, pkgsrc_dir, sizeof pkgsrc_dir); }; 630 option {src_legend(menu, MSG_User, pkgsrc.user);}, 631 action { src_prompt(MSG_User, pkgsrc.user, sizeof pkgsrc.user); 632 pkgsrc.pass[0] = 0; 633 }; 634 option {src_legend(menu, MSG_Password, 635 strcmp(pkgsrc.user, "ftp") == 0 || pkgsrc.pass[0] == 0 636 ? pkgsrc.pass : msg_string(MSG_hidden));}, 637 action { if (strcmp(pkgsrc.user, "ftp") == 0) 638 src_prompt(MSG_email, pkgsrc.pass, sizeof pkgsrc.pass); 639 else { 640 msg_prompt_noecho(MSG_Password, "", 641 pkgsrc.pass, sizeof pkgsrc.pass); 642 } 643 }; 644 option {src_legend(menu, MSG_Proxy, pkgsrc.proxy);}, 645 action { src_prompt(MSG_Proxy, pkgsrc.proxy, sizeof pkgsrc.proxy); 646 if (strcmp(pkgsrc.proxy, "") == 0) { 647 unsetenv("ftp_proxy"); 648 unsetenv("http_proxy"); 649 } else { 650 setenv("ftp_proxy", pkgsrc.proxy, 1); 651 setenv("http_proxy", pkgsrc.proxy, 1); 652 } 653 }; 654 option {src_legend(menu, MSG_Xfer_dir, xfer_dir);}, 655 action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); }; 656 option {src_legend(menu, MSG_delete_xfer_file, 657 clean_xfer_dir ? MSG_Yes : MSG_No);}, 658 action {clean_xfer_dir = ask_yesno(MSG_delete_xfer_file); }; 659 option {src_legend(menu, MSG_transfer_method, url_proto(pkgsrc.xfer));}, 660 action { pkgsrc.xfer = (pkgsrc.xfer+1) % (XFER_MAX+1); }; 661 option MSG_quit_pkgsrc, exit, action { *((int*)arg) = SET_SKIP;}; 662 663menu usersh, title MSG_User_shell, no clear; 664 option "/bin/sh", exit, action { ushell = "/bin/sh";}; 665 option "/bin/ksh", exit, action { ushell = "/bin/ksh";}; 666 option "/bin/csh", exit, action { ushell = "/bin/csh";}; 667 668menu convertscheme, title MSG_cvtscheme_hdr; 669 option MSG_cvtscheme_keep, exit, action { *(int*)arg = 0; }; 670 option MSG_cvtscheme_delete, exit, action { *(int*)arg = 1; }; 671 option MSG_cvtscheme_convert, exit, action { *(int*)arg = 2; }; 672 option MSG_cvtscheme_abort, exit, action { *(int*)arg = 3; }; 673 674 675menu reedit, title MSG_reeditpart, y=-10; 676 expand action { expand_all_option_texts(menu, arg); }; 677 option MSG_reedit_partitions, exit, 678 action {((arg_rep_int*)arg)->rv = 1;}; 679 option MSG_use_partitions_anyway, exit, 680 action {((arg_rep_int*)arg)->rv = 2;}; 681 option MSG_abort_installation, exit, 682 action {((arg_rep_int*)arg)->rv = 0;}; 683