menus.mi revision 1.6 1 1.6 roy /* $NetBSD: menus.mi,v 1.6 2014/09/22 19:01:02 roy Exp $ */
2 1.1 dholland
3 1.1 dholland /*-
4 1.1 dholland * Copyright (c) 2003 The NetBSD Foundation, Inc.
5 1.1 dholland * All rights reserved.
6 1.1 dholland *
7 1.1 dholland * This code is derived from software contributed to The NetBSD Foundation
8 1.1 dholland * by David Laight.
9 1.1 dholland *
10 1.1 dholland * Redistribution and use in source and binary forms, with or without
11 1.1 dholland * modification, are permitted provided that the following conditions
12 1.1 dholland * are met:
13 1.1 dholland * 1. Redistributions of source code must retain the above copyright
14 1.1 dholland * notice, this list of conditions and the following disclaimer.
15 1.1 dholland * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 dholland * notice, this list of conditions and the following disclaimer in the
17 1.1 dholland * documentation and/or other materials provided with the distribution.
18 1.1 dholland *
19 1.1 dholland * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 dholland * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 dholland * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 dholland * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 dholland * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 dholland * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 dholland * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 dholland * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 dholland * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 dholland * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 dholland * POSSIBILITY OF SUCH DAMAGE.
30 1.1 dholland */
31 1.1 dholland
32 1.1 dholland /*
33 1.1 dholland * Menu system definitions -- machine and language independent
34 1.1 dholland *
35 1.1 dholland * Some menus may be called directly in the code rather than via the
36 1.1 dholland * menu system.
37 1.1 dholland *
38 1.1 dholland * This file must be first in the sed command line.
39 1.1 dholland *
40 1.1 dholland */
41 1.1 dholland
42 1.1 dholland {
43 1.1 dholland #include <stdio.h>
44 1.1 dholland #include <time.h>
45 1.1 dholland #include <curses.h>
46 1.1 dholland #include "defs.h"
47 1.1 dholland #include "md.h"
48 1.1 dholland #include "msg_defs.h"
49 1.1 dholland #include "menu_defs.h"
50 1.1 dholland
51 1.2 martin static menudesc menu_def[];
52 1.2 martin
53 1.1 dholland static void
54 1.1 dholland src_legend(menudesc *menu, const char *legend, const char *text)
55 1.1 dholland {
56 1.1 dholland wprintw(menu->mw, "%-25s %.50s", MSG_XLAT(legend), MSG_XLAT(text));
57 1.1 dholland }
58 1.1 dholland
59 1.1 dholland static void
60 1.1 dholland src_prompt(const char *prompt, char *buf, size_t size)
61 1.1 dholland {
62 1.1 dholland msg_prompt_win(prompt, -1, 12, 0, 0, buf, buf, size);
63 1.1 dholland }
64 1.2 martin
65 1.4 martin static void
66 1.4 martin remove_sub_menu(int menuID)
67 1.2 martin {
68 1.2 martin
69 1.2 martin for (size_t i = 0; i < DYN_MENU_START; i++) {
70 1.2 martin for (int j = 0; j < menu_def[i].numopts; j++) {
71 1.2 martin if ((menu_def[i].opts[j].opt_flags & OPT_SUB)
72 1.4 martin && menu_def[i].opts[j].opt_menu == menuID) {
73 1.2 martin
74 1.2 martin for (int k = j + 1; k < menu_def[i].numopts;
75 1.2 martin k++) {
76 1.2 martin menu_def[i].opts[k-1] =
77 1.2 martin menu_def[i].opts[k];
78 1.2 martin }
79 1.2 martin menu_def[i].numopts--;
80 1.2 martin return;
81 1.2 martin
82 1.2 martin }
83 1.2 martin }
84 1.2 martin }
85 1.2 martin }
86 1.2 martin
87 1.4 martin static void
88 1.4 martin remove_menu_option(int menuID, const char *option)
89 1.4 martin {
90 1.4 martin
91 1.4 martin for (int j = 0; j < menu_def[menuID].numopts; j++) {
92 1.4 martin if (menu_def[menuID].opts[j].opt_name == option) {
93 1.4 martin for (int k = j + 1; k < menu_def[menuID].numopts;
94 1.4 martin k++) {
95 1.4 martin menu_def[menuID].opts[k-1] =
96 1.4 martin menu_def[menuID].opts[k];
97 1.4 martin }
98 1.4 martin menu_def[menuID].numopts--;
99 1.4 martin return;
100 1.4 martin
101 1.4 martin }
102 1.4 martin }
103 1.4 martin }
104 1.4 martin
105 1.4 martin void
106 1.4 martin remove_color_options()
107 1.4 martin {
108 1.4 martin /*
109 1.4 martin * Current terminal type does not support colors, so remove all
110 1.4 martin * menu entries (actually that is: Utils/Color Scheme) that do not
111 1.4 martin * make any sense in this case.
112 1.4 martin */
113 1.4 martin remove_sub_menu(MENU_colors);
114 1.4 martin }
115 1.4 martin
116 1.4 martin void
117 1.4 martin remove_raid_options()
118 1.4 martin {
119 1.4 martin /*
120 1.4 martin * No raidframe available, remove the following menu entries:
121 1.4 martin */
122 1.4 martin remove_menu_option(MENU_pmdiskentry, MSG_fmtasraid);
123 1.4 martin remove_menu_option(MENU_pmpartentry, MSG_fmtasraid);
124 1.4 martin }
125 1.4 martin
126 1.4 martin void
127 1.4 martin remove_lvm_options()
128 1.4 martin {
129 1.4 martin /*
130 1.4 martin * No LVM available, remove the following menu entries:
131 1.4 martin */
132 1.4 martin remove_menu_option(MENU_pmdiskentry, MSG_fmtaslvm);
133 1.4 martin remove_menu_option(MENU_pmpartentry, MSG_fmtaslvm);
134 1.4 martin }
135 1.4 martin
136 1.4 martin void
137 1.4 martin remove_gpt_options()
138 1.4 martin {
139 1.4 martin /*
140 1.4 martin * No GPT available, remove the following menu entries:
141 1.4 martin */
142 1.4 martin remove_menu_option(MENU_pmdiskentry, MSG_switchgpt);
143 1.4 martin remove_menu_option(MENU_pmpartentry, MSG_switchgpt);
144 1.4 martin }
145 1.4 martin
146 1.4 martin void
147 1.4 martin remove_cgd_options()
148 1.4 martin {
149 1.4 martin /*
150 1.4 martin * No CGD available, remove the following menu entries:
151 1.4 martin */
152 1.4 martin remove_menu_option(MENU_pmdiskentry, MSG_encrypt);
153 1.4 martin remove_menu_option(MENU_pmpartentry, MSG_encrypt);
154 1.4 martin }
155 1.4 martin
156 1.1 dholland }
157 1.1 dholland
158 1.1 dholland default y=12, no exit, scrollable;
159 1.1 dholland
160 1.1 dholland allow dynamic menus;
161 1.1 dholland allow dynamic messages;
162 1.1 dholland error action {
163 1.1 dholland fprintf (stderr, "Could not initialize menu system, please check "
164 1.1 dholland "your terminal type.\n");
165 1.1 dholland exit(4);
166 1.1 dholland };
167 1.1 dholland
168 1.1 dholland menu selfskind, title MSG_Select_the_type, exitstring MSG_unchanged, y=6, x=30;
169 1.1 dholland display action {
170 1.1 dholland partinfo *p = arg;
171 1.1 dholland switch (p->pi_fstype) {
172 1.1 dholland case FS_UNUSED: menu->cursel = 0; break;
173 1.1 dholland case FS_BSDFFS:
174 1.1 dholland menu->cursel = p->pi_flags & PIF_FFSv2 ? 2 : 1;
175 1.1 dholland break;
176 1.1 dholland case FS_SWAP: menu->cursel = 3; break;
177 1.1 dholland case FS_MSDOS: menu->cursel = 4; break;
178 1.1 dholland case FS_BSDLFS: menu->cursel = 5; break;
179 1.1 dholland default : menu->cursel = 6; break;
180 1.1 dholland };
181 1.1 dholland };
182 1.1 dholland option "unused", exit, action
183 1.1 dholland { memset(arg, 0, sizeof (partinfo)); };
184 1.1 dholland option "FFSv1", exit, action { set_ptype(arg, FS_BSDFFS, 0); };
185 1.1 dholland option "FFSv2", exit, action { set_ptype(arg, FS_BSDFFS, PIF_FFSv2); };
186 1.1 dholland option "swap", exit, action { set_ptype(arg, FS_SWAP, 0); };
187 1.1 dholland option "msdos", exit, action { set_ptype(arg, FS_MSDOS, 0); };
188 1.1 dholland option "LFS", exit, action { set_ptype(arg, FS_BSDLFS, 0); };
189 1.1 dholland option MSG_other_types, action
190 1.1 dholland { extern int all_fstype_menu;
191 1.1 dholland m->opts[m->cursel].opt_menu = all_fstype_menu; };
192 1.1 dholland
193 1.1 dholland menu selbsize, title MSG_Select_file_system_block_size, y=10, x=40;
194 1.1 dholland display action {
195 1.1 dholland partinfo *pi = arg;
196 1.1 dholland int b;
197 1.1 dholland b = ffs(pi->pi_fsize * pi->pi_frag / 4096) - 1;
198 1.1 dholland if (b < 0 || b >= menu->numopts)
199 1.1 dholland b = 1;
200 1.1 dholland menu->cursel = b;
201 1.1 dholland };
202 1.1 dholland option "4096", exit, action { set_bsize(arg, 4096); };
203 1.1 dholland option "8192", exit, action { set_bsize(arg, 8192); };
204 1.1 dholland option "16384", exit, action { set_bsize(arg, 16384); };
205 1.1 dholland option "32768", exit, action { set_bsize(arg, 32768); };
206 1.1 dholland
207 1.1 dholland menu selfsize, title MSG_Select_file_system_fragment_size, y=11, x=40;
208 1.1 dholland display action {
209 1.1 dholland partinfo *pi = arg;
210 1.1 dholland int b;
211 1.1 dholland b = ffs(pi->pi_fsize / 512) - 1;
212 1.1 dholland if (b < 0 || b >= menu->numopts)
213 1.1 dholland b = 1;
214 1.1 dholland menu->cursel = b;
215 1.1 dholland };
216 1.1 dholland option "512", exit, action { set_fsize(arg, 512); };
217 1.1 dholland option "1024", exit, action { set_fsize(arg, 1024); };
218 1.1 dholland option "2048", exit, action { set_fsize(arg, 2048); };
219 1.1 dholland option "4096", exit, action { set_fsize(arg, 4096); };
220 1.1 dholland option "8192", exit, action { set_fsize(arg, 8192); };
221 1.1 dholland option "16384", exit, action { set_fsize(arg, 16384); };
222 1.1 dholland option "32768", exit, action { set_fsize(arg, 32768); };
223 1.1 dholland
224 1.1 dholland menu mountoptions, title MSG_toggle, y=5, x=30, exitstring MSG_unchanged;
225 1.1 dholland display action {
226 1.1 dholland static int actual_numopt;
227 1.1 dholland if (!actual_numopt)
228 1.1 dholland actual_numopt = menu->numopts;
229 1.1 dholland menu->numopts = actual_numopt -
230 1.1 dholland (((partinfo *)arg)->pi_fstype != FS_BSDFFS);
231 1.1 dholland };
232 1.1 dholland option "log", exit, action
233 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_LOG; };
234 1.1 dholland option "async", exit, action
235 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_ASYNC; };
236 1.1 dholland option "noatime", exit, action
237 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_NOATIME; };
238 1.1 dholland option "nodev", exit, action
239 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_NODEV; };
240 1.1 dholland option "nodevmtime", exit, action
241 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_NODEVMTIME; };
242 1.1 dholland option "noexec", exit, action
243 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_NOEXEC; };
244 1.1 dholland option "nosuid", exit, action
245 1.1 dholland { ((partinfo *)arg)->pi_flags ^= PIF_NOSUID; };
246 1.1 dholland
247 1.1 dholland menu netbsd, title MSG_NetBSD_VERSION_Install_System, y=-1,
248 1.1 dholland exit, exitstring MSG_Exit_Install_System;
249 1.1 dholland display action { toplevel(); };
250 1.1 dholland option MSG_Install_NetBSD_to_hard_disk,
251 1.1 dholland action { do_install(); };
252 1.1 dholland option MSG_Upgrade_NetBSD_on_a_hard_disk,
253 1.1 dholland action { do_upgrade(); };
254 1.1 dholland option MSG_Re_install_sets_or_install_additional_sets,
255 1.1 dholland action { do_reinstall_sets(); };
256 1.1 dholland option MSG_Reboot_the_computer, exit,
257 1.1 dholland action (endwin) { system("/sbin/reboot -q"); };
258 1.1 dholland option MSG_Utility_menu, sub menu utility;
259 1.1 dholland option MSG_Config_menu, action { do_configmenu(); };
260 1.1 dholland
261 1.1 dholland menu utility, title MSG_NetBSD_VERSION_Utilities, exit,
262 1.2 martin exitstring MSG_exit_menu_generic;
263 1.1 dholland display action { toplevel(); };
264 1.1 dholland option MSG_Run_bin_sh,
265 1.1 dholland action (endwin) { system("/bin/sh"); };
266 1.1 dholland option MSG_Set_timezone,
267 1.1 dholland action { set_timezone(); };
268 1.1 dholland option MSG_Configure_network,
269 1.1 dholland action {
270 1.1 dholland extern int network_up;
271 1.1 dholland network_up = 0;
272 1.1 dholland config_network();
273 1.1 dholland };
274 1.2 martin option MSG_Partition_a_disk, action { partman_go = 1; partman(); };
275 1.1 dholland option MSG_Logging_functions, action { do_logging(); };
276 1.2 martin option MSG_Color_scheme, sub menu colors;
277 1.1 dholland option MSG_Halt_the_system, exit,
278 1.1 dholland action (endwin) { system("/sbin/halt -q"); };
279 1.1 dholland
280 1.2 martin menu colors, title MSG_Color_scheme, exit,
281 1.2 martin exitstring MSG_exit_menu_generic;
282 1.2 martin option MSG_White_on_black, action { do_coloring(COLOR_WHITE,COLOR_BLACK); };
283 1.2 martin option MSG_Black_on_white, action { do_coloring(COLOR_BLACK,COLOR_WHITE); };
284 1.2 martin option MSG_White_on_blue, action { do_coloring(COLOR_WHITE,COLOR_BLUE); };
285 1.2 martin option MSG_Green_on_black, action { do_coloring(COLOR_GREEN,COLOR_BLACK); };
286 1.2 martin
287 1.2 martin
288 1.1 dholland menu yesno, y=-10;
289 1.1 dholland display action { menu->title = arg ? arg : MSG_yes_or_no; };
290 1.1 dholland option MSG_Yes, exit, action {yesno = 1;};
291 1.1 dholland option MSG_No, exit, action {yesno = 0;};
292 1.1 dholland
293 1.1 dholland menu noyes, y=-10;
294 1.1 dholland display action { menu->title = arg ? arg : MSG_yes_or_no; };
295 1.1 dholland option MSG_No, exit, action {yesno = 0;};
296 1.1 dholland option MSG_Yes, exit, action {yesno = 1;};
297 1.1 dholland
298 1.1 dholland menu ok, no shortcut, y=-10;
299 1.1 dholland display action { menu->title = arg; };
300 1.1 dholland option MSG_Hit_enter_to_continue, exit;
301 1.1 dholland
302 1.1 dholland menu layout, sub menu, y=-1, title MSG_Choose_your_installation;
303 1.2 martin option MSG_Set_Sizes, exit, action { layoutkind = LY_SETNEW; };
304 1.2 martin option MSG_Use_Existing, exit, action { layoutkind = LY_USEEXIST; };
305 1.1 dholland
306 1.1 dholland menu sizechoice, sub menu, y=0, title MSG_Choose_your_size_specifier;
307 1.1 dholland display action {
308 1.2 martin if (sizemult == pm->current_cylsize)
309 1.1 dholland menu->cursel = 1;
310 1.1 dholland else if (sizemult == 1)
311 1.1 dholland menu->cursel = 2;
312 1.1 dholland };
313 1.1 dholland option MSG_Megabytes, exit, action
314 1.2 martin { sizemult = MEG / pm->sectorsize;
315 1.1 dholland multname = msg_string(MSG_megname);
316 1.1 dholland };
317 1.1 dholland option MSG_Cylinders, exit, action
318 1.2 martin { sizemult = pm->current_cylsize;
319 1.1 dholland multname = msg_string(MSG_cylname);
320 1.1 dholland };
321 1.1 dholland option MSG_Sectors, exit, action
322 1.1 dholland { sizemult = 1;
323 1.1 dholland multname = msg_string(MSG_secname);
324 1.1 dholland };
325 1.1 dholland
326 1.1 dholland menu distmedium, title MSG_Select_medium, y=-5;
327 1.1 dholland option MSG_cdrom, exit, action { *(int *)arg = get_via_cdrom(); };
328 1.1 dholland option MSG_ftp, exit, action { *(int *)arg = get_via_ftp("ftp"); };
329 1.1 dholland option MSG_http, exit, action { *(int *)arg = get_via_ftp("http"); };
330 1.1 dholland option MSG_nfs, exit, action { *(int *)arg = get_via_nfs(); };
331 1.1 dholland option MSG_floppy, exit, action { *(int *)arg = get_via_floppy(); };
332 1.1 dholland option MSG_local_fs, exit, action { *(int *)arg = get_via_localfs(); };
333 1.1 dholland option MSG_local_dir, exit, action { *(int *)arg = get_via_localdir();};
334 1.1 dholland option MSG_Skip_set, exit, action { *(int *)arg = SET_SKIP; };
335 1.1 dholland option MSG_Skip_group,exit, action { *(int *)arg = SET_SKIP_GROUP; };
336 1.1 dholland option MSG_Abandon, exit, action { *(int *)arg = SET_ABANDON; };
337 1.1 dholland
338 1.3 martin menu distset, title MSG_Select_your_distribution, exit,
339 1.3 martin no default exit, exitstring MSG_Abandon;
340 1.1 dholland display action { msg_display (MSG_distset); };
341 1.2 martin option MSG_Full_installation, exit, action { *(int *)arg = 1; init_set_status(0); };
342 1.2 martin option MSG_Full_installation_nox, exit, action { *(int *)arg = 1; init_set_status(SFLAG_NOX); };
343 1.2 martin option MSG_Minimal_installation, exit, action { *(int *)arg = 1; init_set_status(SFLAG_MINIMAL); };
344 1.2 martin option MSG_Custom_installation, exit, action { *(int *)arg = 1; init_set_status(SFLAG_MINIMAL); customise_sets(); };
345 1.1 dholland
346 1.1 dholland menu ftpsource, y=-4, x=0, w=70, no box, no clear,
347 1.1 dholland exitstring MSG_Get_Distribution;
348 1.1 dholland display action { msg_display(MSG_ftpsource, arg); };
349 1.1 dholland option {src_legend(menu, MSG_Host, ftp.host);},
350 1.1 dholland action { src_prompt(MSG_Host, ftp.host, sizeof ftp.host); };
351 1.1 dholland option {src_legend(menu, MSG_Base_dir, ftp.dir);},
352 1.1 dholland action { src_prompt(MSG_Base_dir, ftp.dir, sizeof ftp.dir); };
353 1.1 dholland option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);},
354 1.1 dholland action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); };
355 1.1 dholland option {src_legend(menu, MSG_Set_dir_src, set_dir_src);},
356 1.1 dholland action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); };
357 1.1 dholland option {src_legend(menu, MSG_User, ftp.user);},
358 1.1 dholland action { src_prompt(MSG_User, ftp.user, sizeof ftp.user);
359 1.1 dholland ftp.pass[0] = 0;
360 1.1 dholland };
361 1.1 dholland option {src_legend(menu, MSG_Password,
362 1.1 dholland strcmp(ftp.user, "ftp") == 0 || ftp.pass[0] == 0
363 1.1 dholland ? ftp.pass : msg_string(MSG_hidden));},
364 1.1 dholland action { if (strcmp(ftp.user, "ftp") == 0)
365 1.1 dholland src_prompt(MSG_email, ftp.pass, sizeof ftp.pass);
366 1.1 dholland else {
367 1.1 dholland msg_prompt_noecho(MSG_Password, "",
368 1.1 dholland ftp.pass, sizeof ftp.pass);
369 1.1 dholland }
370 1.1 dholland };
371 1.1 dholland option {src_legend(menu, MSG_Proxy, ftp.proxy);},
372 1.1 dholland action { src_prompt(MSG_Proxy, ftp.proxy, sizeof ftp.proxy);
373 1.1 dholland if (strcmp(ftp.proxy, "") == 0) {
374 1.1 dholland unsetenv("ftp_proxy");
375 1.1 dholland unsetenv("http_proxy");
376 1.1 dholland } else {
377 1.1 dholland setenv("ftp_proxy", ftp.proxy, 1);
378 1.1 dholland setenv("http_proxy", ftp.proxy, 1);
379 1.1 dholland }
380 1.1 dholland };
381 1.1 dholland option {src_legend(menu, MSG_Xfer_dir, xfer_dir);},
382 1.1 dholland action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); };
383 1.1 dholland option {src_legend(menu, MSG_delete_xfer_file,
384 1.1 dholland clean_xfer_dir ? MSG_Yes : MSG_No);},
385 1.1 dholland action {process_menu(MENU_yesno, deconst(MSG_delete_xfer_file));
386 1.1 dholland clean_xfer_dir = yesno; };
387 1.2 martin option MSG_Configure_network,
388 1.2 martin action {
389 1.2 martin extern int network_up;
390 1.2 martin network_up = 0;
391 1.2 martin config_network();
392 1.2 martin };
393 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
394 1.1 dholland
395 1.1 dholland
396 1.1 dholland menu nfssource, y=-4, x=0, w=70, no box, no clear,
397 1.2 martin exitstring MSG_Get_Distribution;
398 1.1 dholland display action { msg_display(MSG_nfssource); };
399 1.1 dholland option {src_legend(menu, MSG_Host, nfs_host);},
400 1.1 dholland action { src_prompt(MSG_Host, nfs_host, sizeof nfs_host); };
401 1.1 dholland option {src_legend(menu, MSG_Base_dir, nfs_dir);},
402 1.1 dholland action { src_prompt(MSG_Base_dir, nfs_dir, sizeof nfs_dir); };
403 1.1 dholland option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);},
404 1.1 dholland action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); };
405 1.1 dholland option {src_legend(menu, MSG_Set_dir_src, set_dir_src);},
406 1.1 dholland action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); };
407 1.2 martin option MSG_Configure_network,
408 1.2 martin action {
409 1.2 martin extern int network_up;
410 1.2 martin network_up = 0;
411 1.2 martin config_network();
412 1.2 martin };
413 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
414 1.1 dholland
415 1.1 dholland menu fdremount, title MSG_What_do_you_want_to_do;
416 1.1 dholland option MSG_Try_again, exit, action { *(int *)arg = SET_CONTINUE; };
417 1.1 dholland option MSG_Set_finished, exit, action { *(int *)arg = SET_OK; };
418 1.1 dholland option MSG_Abort_fetch, exit, action { *(int *)arg = SET_RETRY; };
419 1.1 dholland
420 1.1 dholland menu fdok, title MSG_What_do_you_want_to_do;
421 1.1 dholland option MSG_OK, exit, action { *(int *)arg = SET_CONTINUE; };
422 1.1 dholland option MSG_Set_finished, exit, action { *(int *)arg = SET_OK; };
423 1.1 dholland option MSG_Abort_fetch, exit, action { *(int *)arg = SET_RETRY; };
424 1.1 dholland
425 1.1 dholland menu fd_type, title MSG_fd_type, y=16;
426 1.1 dholland option "msdos", exit, action { fd_type = "msdos"; };
427 1.1 dholland option "ffs", exit, action { fd_type = "ffs"; };
428 1.1 dholland .if ADOS_FLOPPY
429 1.1 dholland option "ados", exit, action { fd_type = "ados"; };
430 1.1 dholland .endif
431 1.1 dholland
432 1.1 dholland menu floppysource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue;
433 1.1 dholland display action { msg_display(MSG_floppysource); };
434 1.1 dholland option {src_legend(menu, MSG_Device, fd_dev);},
435 1.1 dholland action { src_prompt(MSG_dev, fd_dev, sizeof fd_dev); };
436 1.1 dholland option {src_legend(menu, MSG_fd_type, fd_type);}, sub menu fd_type;
437 1.1 dholland option {src_legend(menu, MSG_Xfer_dir, xfer_dir);},
438 1.1 dholland action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); };
439 1.1 dholland option {src_legend(menu, MSG_delete_xfer_file,
440 1.1 dholland clean_xfer_dir ? MSG_Yes : MSG_No);},
441 1.1 dholland action {process_menu(MENU_yesno, deconst(MSG_delete_xfer_file));
442 1.1 dholland clean_xfer_dir = yesno; };
443 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
444 1.1 dholland
445 1.1 dholland menu cdromsource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue;
446 1.1 dholland display action { msg_display(MSG_cdromsource); };
447 1.1 dholland option {src_legend(menu, MSG_Device, cdrom_dev);},
448 1.1 dholland action { src_prompt(MSG_dev, cdrom_dev, sizeof cdrom_dev); };
449 1.1 dholland option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);},
450 1.1 dholland action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); };
451 1.1 dholland option {src_legend(menu, MSG_Set_dir_src, set_dir_src);},
452 1.1 dholland action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); };
453 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
454 1.1 dholland
455 1.1 dholland menu localfssource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue;
456 1.1 dholland display action { msg_display(MSG_localfssource); };
457 1.1 dholland option {src_legend(menu, MSG_Device, localfs_dev);},
458 1.1 dholland action { src_prompt(MSG_dev, localfs_dev, sizeof localfs_dev);};
459 1.1 dholland option {src_legend(menu, MSG_File_system, localfs_fs);},
460 1.1 dholland action { src_prompt(MSG_filesys, localfs_fs, sizeof localfs_fs); };
461 1.1 dholland option {src_legend(menu, MSG_Base_dir, localfs_dir);},
462 1.1 dholland action { src_prompt(MSG_Base_dir, localfs_dir, sizeof localfs_dir);};
463 1.1 dholland option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);},
464 1.1 dholland action { src_prompt(MSG_Set_dir_bin, set_dir_bin, sizeof set_dir_bin); };
465 1.1 dholland option {src_legend(menu, MSG_Set_dir_src, set_dir_src);},
466 1.1 dholland action { src_prompt(MSG_Set_dir_src, set_dir_src, sizeof set_dir_src); };
467 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
468 1.1 dholland
469 1.1 dholland menu localdirsource, y=-4, x=0, w=70, no box, no clear, exitstring MSG_Continue;
470 1.1 dholland display action { msg_display(MSG_localdir); };
471 1.1 dholland option {src_legend(menu, MSG_Base_dir, localfs_dir);},
472 1.1 dholland action { src_prompt(MSG_Base_dir, localfs_dir, 60); };
473 1.1 dholland option {src_legend(menu, MSG_Set_dir_bin, set_dir_bin);},
474 1.1 dholland action { src_prompt(MSG_Set_dir_bin, set_dir_bin, 60); };
475 1.1 dholland option {src_legend(menu, MSG_Set_dir_src, set_dir_src);},
476 1.1 dholland action { src_prompt(MSG_Set_dir_src, set_dir_src, 60); };
477 1.2 martin option MSG_exit_menu_generic, exit, action { yesno = SET_RETRY; };
478 1.1 dholland
479 1.6 roy menu namesrv6, title MSG_Select_DNS_server;
480 1.6 roy option "google-public-dns-a.google.com (IPv4)", exit, action
481 1.6 roy {
482 1.6 roy #ifdef INET6
483 1.6 roy strlcpy(net_namesvr, "8.8.8.8",
484 1.6 roy sizeof(net_namesvr));
485 1.6 roy yesno = 1;
486 1.6 roy #else
487 1.6 roy yesno = 0;
488 1.6 roy #endif
489 1.6 roy };
490 1.6 roy option "google-public-dns-b.google.com (IPv4)", exit, action
491 1.6 roy {
492 1.6 roy #ifdef INET6
493 1.6 roy strlcpy(net_namesvr, "8.8.4.4",
494 1.6 roy sizeof(net_namesvr));
495 1.6 roy yesno = 1;
496 1.6 roy #else
497 1.6 roy yesno = 0;
498 1.6 roy #endif
499 1.6 roy };
500 1.6 roy option "google-public-dns-a.google.com (IPv6)", exit, action
501 1.1 dholland {
502 1.1 dholland #ifdef INET6
503 1.5 roy strlcpy(net_namesvr, "2001:4860:4860::8888",
504 1.5 roy sizeof(net_namesvr));
505 1.1 dholland yesno = 1;
506 1.1 dholland #else
507 1.1 dholland yesno = 0;
508 1.1 dholland #endif
509 1.1 dholland };
510 1.6 roy option "google-public-dns-b.google.com (IPv6)", exit, action
511 1.1 dholland {
512 1.1 dholland #ifdef INET6
513 1.5 roy strlcpy(net_namesvr, "2001:4860:4860::8844",
514 1.5 roy sizeof(net_namesvr));
515 1.1 dholland yesno = 1;
516 1.1 dholland #else
517 1.1 dholland yesno = 0;
518 1.1 dholland #endif
519 1.1 dholland };
520 1.1 dholland option MSG_other, exit, action
521 1.1 dholland { yesno = 0; };
522 1.1 dholland
523 1.1 dholland menu rootsh, title MSG_Root_shell, no clear;
524 1.1 dholland option "/bin/sh", exit, action {*(const char **)arg = "/bin/sh";};
525 1.1 dholland option "/bin/ksh", exit, action {*(const char **)arg = "/bin/ksh";};
526 1.1 dholland option "/bin/csh", exit, action {*(const char **)arg = "/bin/csh";};
527 1.1 dholland
528 1.1 dholland menu zeroconf, title "Zeroconf", no clear;
529 1.1 dholland option "run mdnsd only", exit, action {*(const char **)arg = "mdnsd";};
530 1.1 dholland option "run mdnsd and resolve local names", exit, action {*(const char **) arg = "mdnsd+nsswitch";};
531 1.1 dholland option "do not run mdnsd", exit, action {*(const char **)arg = "No";};
532 1.1 dholland
533 1.1 dholland menu binpkg, y=-4, x=0, w=70, no box, no clear,
534 1.1 dholland exitstring MSG_Install_pkgin;
535 1.1 dholland display action { msg_display(MSG_pkgpath); };
536 1.1 dholland option {src_legend(menu, MSG_Host, pkg.host);},
537 1.1 dholland action { src_prompt(MSG_Host, pkg.host, sizeof pkg.host); };
538 1.1 dholland option {src_legend(menu, MSG_Base_dir, pkg.dir);},
539 1.1 dholland action { src_prompt(MSG_Base_dir, pkg.dir, sizeof pkg.dir); };
540 1.1 dholland option {src_legend(menu, MSG_Pkg_dir, pkg_dir);},
541 1.1 dholland action { src_prompt(MSG_Pkg_dir, pkg_dir, sizeof pkg_dir); };
542 1.1 dholland option {src_legend(menu, MSG_User, pkg.user);},
543 1.1 dholland action { src_prompt(MSG_User, pkg.user, sizeof pkg.user);
544 1.1 dholland pkg.pass[0] = 0;
545 1.1 dholland };
546 1.1 dholland option {src_legend(menu, MSG_Password,
547 1.1 dholland strcmp(pkg.user, "ftp") == 0 || pkg.pass[0] == 0
548 1.1 dholland ? pkg.pass : msg_string(MSG_hidden));},
549 1.1 dholland action { if (strcmp(pkg.user, "ftp") == 0)
550 1.1 dholland src_prompt(MSG_email, pkg.pass, sizeof pkg.pass);
551 1.1 dholland else {
552 1.1 dholland msg_prompt_noecho(MSG_Password, "",
553 1.1 dholland pkg.pass, sizeof pkg.pass);
554 1.1 dholland }
555 1.1 dholland };
556 1.1 dholland option {src_legend(menu, MSG_Proxy, pkg.proxy);},
557 1.1 dholland action { src_prompt(MSG_Proxy, pkg.proxy, sizeof pkg.proxy);
558 1.1 dholland if (strcmp(pkg.proxy, "") == 0) {
559 1.1 dholland unsetenv("ftp_proxy");
560 1.1 dholland unsetenv("http_proxy");
561 1.1 dholland } else {
562 1.1 dholland setenv("ftp_proxy", pkg.proxy, 1);
563 1.1 dholland setenv("http_proxy", pkg.proxy, 1);
564 1.1 dholland }
565 1.1 dholland };
566 1.2 martin option {src_legend(menu, "Additional packages", (char*)arg); }, /*TODO*/
567 1.2 martin action { src_prompt("Additional packages", (char*)arg,
568 1.2 martin sizeof(char) * STRSIZE); };
569 1.2 martin option MSG_Configure_network,
570 1.2 martin action {
571 1.2 martin extern int network_up;
572 1.2 martin network_up = 0;
573 1.2 martin config_network();
574 1.2 martin mnt_net_config();
575 1.2 martin };
576 1.2 martin option MSG_quit_pkgs_install, exit, action { yesno = SET_SKIP; };
577 1.1 dholland
578 1.1 dholland menu pkgsrc, y=-4, x=0, w=70, no box, no clear,
579 1.1 dholland exit, exitstring MSG_Install_pkgsrc;
580 1.1 dholland display action { msg_display(MSG_pkgsrc); };
581 1.1 dholland option {src_legend(menu, MSG_Host, pkgsrc.host);},
582 1.1 dholland action { src_prompt(MSG_Host, pkgsrc.host,
583 1.1 dholland sizeof pkgsrc.host); };
584 1.1 dholland option {src_legend(menu, MSG_Pkgsrc_dir, pkgsrc_dir);},
585 1.1 dholland action { src_prompt(MSG_Pkgsrc_dir, pkgsrc_dir, sizeof pkgsrc_dir); };
586 1.1 dholland option {src_legend(menu, MSG_User, pkgsrc.user);},
587 1.1 dholland action { src_prompt(MSG_User, pkgsrc.user, sizeof pkgsrc.user);
588 1.1 dholland pkgsrc.pass[0] = 0;
589 1.1 dholland };
590 1.1 dholland option {src_legend(menu, MSG_Password,
591 1.1 dholland strcmp(pkgsrc.user, "ftp") == 0 || pkgsrc.pass[0] == 0
592 1.1 dholland ? pkgsrc.pass : msg_string(MSG_hidden));},
593 1.1 dholland action { if (strcmp(pkgsrc.user, "ftp") == 0)
594 1.1 dholland src_prompt(MSG_email, pkgsrc.pass, sizeof pkgsrc.pass);
595 1.1 dholland else {
596 1.1 dholland msg_prompt_noecho(MSG_Password, "",
597 1.1 dholland pkgsrc.pass, sizeof pkgsrc.pass);
598 1.1 dholland }
599 1.1 dholland };
600 1.1 dholland option {src_legend(menu, MSG_Proxy, pkgsrc.proxy);},
601 1.1 dholland action { src_prompt(MSG_Proxy, pkgsrc.proxy, sizeof pkgsrc.proxy);
602 1.1 dholland if (strcmp(pkgsrc.proxy, "") == 0) {
603 1.1 dholland unsetenv("ftp_proxy");
604 1.1 dholland unsetenv("http_proxy");
605 1.1 dholland } else {
606 1.1 dholland setenv("ftp_proxy", pkgsrc.proxy, 1);
607 1.1 dholland setenv("http_proxy", pkgsrc.proxy, 1);
608 1.1 dholland }
609 1.1 dholland };
610 1.1 dholland option {src_legend(menu, MSG_Xfer_dir, xfer_dir);},
611 1.1 dholland action { src_prompt(MSG_Xfer_dir, xfer_dir, sizeof xfer_dir); };
612 1.1 dholland option {src_legend(menu, MSG_delete_xfer_file,
613 1.1 dholland clean_xfer_dir ? MSG_Yes : MSG_No);},
614 1.1 dholland action {process_menu(MENU_yesno, deconst(MSG_delete_xfer_file));
615 1.1 dholland clean_xfer_dir = yesno; };
616 1.1 dholland option MSG_quit_pkgsrc, exit, action { yesno = 0;};
617 1.1 dholland
618 1.1 dholland menu usersh, title MSG_User_shell, no clear;
619 1.1 dholland option "/bin/sh", exit, action { ushell = "/bin/sh";};
620 1.1 dholland option "/bin/ksh", exit, action { ushell = "/bin/ksh";};
621 1.1 dholland option "/bin/csh", exit, action { ushell = "/bin/csh";};
622 1.2 martin
623 1.2 martin
624 1.2 martin menu pmdiskentry, x=50, y=5, exit, default exit;
625 1.2 martin option MSG_editbsdpart, exit, action { pm_make_bsd_partitions(pm); };
626 1.2 martin option MSG_editmbr, exit, action { md_get_info();
627 1.2 martin md_pre_disklabel();
628 1.2 martin memset(&pm->bsdlabel, 0, sizeof pm->bsdlabel);};
629 1.2 martin option MSG_switchgpt, exit, action { if (pm_gpt_convert(pm) == 0)
630 1.2 martin pm_partusage(pm, -1, 1); };
631 1.2 martin option MSG_renamedisk, exit, action { pm->unsaved = 1; pm_rename(pm); };
632 1.2 martin option MSG_fmtasraid, exit, action { pm->unsaved = 1;
633 1.2 martin pm_partusage(pm, -1, 1);
634 1.2 martin layoutkind = LY_NEWRAID;
635 1.2 martin md_make_bsd_partitions();};
636 1.2 martin option MSG_fmtaslvm, exit, action { pm->unsaved = 1;
637 1.2 martin pm_partusage(pm, -1, 1);
638 1.2 martin layoutkind = LY_NEWLVM;
639 1.2 martin md_make_bsd_partitions(); };
640 1.2 martin option MSG_encrypt, exit, action { pm->unsaved = 1;
641 1.2 martin pm_partusage(pm, -1, 1);
642 1.2 martin layoutkind = LY_NEWCGD;
643 1.2 martin md_make_bsd_partitions();
644 1.2 martin pm_cgd_edit(0, &(part_entry_t)
645 1.2 martin {.dev_ptr = pm, .dev_num = PART_E}
646 1.2 martin ); };
647 1.2 martin option MSG_setbootable, exit, action { pm->unsaved = 1;
648 1.2 martin pm->bootable = !pm->bootable; };
649 1.2 martin option MSG_erase, next menu shred_modes;
650 1.2 martin option MSG_undo, exit, action { label_read(); pm->unsaved = 0;
651 1.2 martin pm_partusage(pm, -1, 1); };
652 1.2 martin option MSG_unconfig, exit, action { if (pm_unconfigure(pm) == 0)
653 1.2 martin pm_partusage(pm, -1, 1); };
654 1.2 martin
655 1.2 martin menu pmpartentry, x=50, y=5, exit, default exit;
656 1.2 martin option MSG_edit, exit, action {
657 1.2 martin pm->unsaved = 1;
658 1.2 martin int tpfs = pm->bsdlabel[*(int*)arg].pi_fstype;
659 1.2 martin int tplvm = pm->bsdlabel[*(int*)arg].lvmpv;
660 1.2 martin pm_editpart(*(int*)arg);
661 1.2 martin if (tpfs != pm->bsdlabel[*(int*)arg].pi_fstype ||
662 1.2 martin tplvm != pm->bsdlabel[*(int*)arg].lvmpv)
663 1.2 martin /* Oops, partition type changed */
664 1.2 martin pm_partusage(pm, *(int*)arg, 1);
665 1.2 martin };
666 1.2 martin option MSG_fmtasraid, exit, action {
667 1.2 martin if (pm->gpt || pm->isspecial) {
668 1.2 martin process_menu(MENU_ok, deconst(MSG_notsupported));
669 1.2 martin return -1;
670 1.2 martin }
671 1.2 martin pm->unsaved = 1;
672 1.2 martin pm_partusage(pm, *(int*)arg, 1);
673 1.2 martin pm_setfstype(pm, *(int*)arg, FS_RAID);
674 1.2 martin };
675 1.2 martin option MSG_fmtaslvm, exit, action {
676 1.2 martin if (pm->gpt || pm->isspecial) {
677 1.2 martin process_menu(MENU_ok, deconst(MSG_notsupported));
678 1.2 martin return -1;
679 1.2 martin }
680 1.2 martin pm->unsaved = 1;
681 1.2 martin pm_partusage(pm, *(int*)arg, 1);
682 1.2 martin pm_setfstype(pm, *(int*)arg, FS_BSDFFS);
683 1.2 martin pm->bsdlabel[*(int*)arg].lvmpv = 1;
684 1.2 martin };
685 1.2 martin option MSG_encrypt, exit, action {
686 1.2 martin if (pm->gpt || pm->isspecial) {
687 1.2 martin process_menu(MENU_ok, deconst(MSG_notsupported));
688 1.2 martin return -1;
689 1.2 martin }
690 1.2 martin pm->unsaved = 1;
691 1.2 martin pm_partusage(pm, *(int*)arg, 1);
692 1.2 martin pm_setfstype(pm, *(int*)arg, FS_CGD);
693 1.2 martin pm_cgd_edit(0,
694 1.2 martin &(part_entry_t){.dev_ptr = pm,
695 1.2 martin .dev_num = *(int*)arg});
696 1.2 martin };
697 1.2 martin option MSG_erase, next menu shred_modes;
698 1.2 martin option MSG_doumount, exit, action { pm_umount(pm, *(int*)arg); };
699 1.2 martin option MSG_Delete_partition, exit, action {
700 1.2 martin pm->unsaved = 1;
701 1.2 martin pm_partusage(pm, *(int*)arg, 1);
702 1.2 martin if (pm->isspecial)
703 1.2 martin pm_unconfigure(pm);
704 1.2 martin else
705 1.2 martin pm->bsdlabel[*(int*)arg].pi_fstype = FS_UNUSED;
706 1.2 martin };
707 1.2 martin
708 1.2 martin menu pmgptentry, x=50, y=8, exit, default exit;
709 1.2 martin option MSG_editbsdpart, exit, action { pm_make_bsd_partitions(pm); };
710 1.2 martin option MSG_switchmbr, exit, action { if (pm_gpt_convert(pm) == 0)
711 1.2 martin pm_partusage(pm, -1, 1); };
712 1.2 martin option MSG_setbootable, exit, action { pm->unsaved = 1;
713 1.2 martin pm->bootable = !pm->bootable; };
714 1.2 martin option MSG_erase, next menu shred_modes;
715 1.2 martin option MSG_undo, exit, action { label_read(); pm->unsaved = 0;
716 1.2 martin pm_partusage(pm, -1, 1); };
717 1.2 martin option MSG_unconfig, exit, action { if (pm_unconfigure(pm) == 0)
718 1.2 martin pm_partusage(pm, -1, 1); };
719 1.2 martin
720 1.2 martin menu shred_modes, x=50, y=5, exit, default exit;
721 1.2 martin option MSG_fillzeros, exit,
722 1.2 martin action { pm_shred(pm, *(int*)arg, SHRED_ZEROS); };
723 1.2 martin option MSG_fillrandom, exit,
724 1.2 martin action { pm_shred(pm, *(int*)arg, SHRED_RANDOM); };
725 1.2 martin option MSG_fillcrypto, exit,
726 1.2 martin action { pm_shred(pm, *(int*)arg, SHRED_CRYPTO); };
727 1.2 martin
728 1.2 martin menu raidlevel;
729 1.2 martin option MSG_raid0, exit, action { *(int *)arg = 0; };
730 1.2 martin option MSG_raid1, exit, action { *(int *)arg = 1; };
731 1.2 martin option MSG_raid4, exit, action { *(int *)arg = 4; };
732 1.2 martin option MSG_raid5, exit, action { *(int *)arg = 5; };
733 1.2 martin
734 1.2 martin menu cgd_enctype;
735 1.2 martin option "aes-cbc", exit, action { *(const char**)arg = "aes-cbc"; };
736 1.2 martin option "3des-cbc", exit, action { *(const char**)arg = "3des-cbc"; };
737 1.2 martin option "blowfish-cbc", exit, action { *(const char**)arg = "blowfish-cbc"; };
738 1.2 martin
739 1.2 martin menu cgd_ivtype;
740 1.2 martin option "encblkno1", exit, action { *(const char**)arg = "encblkno1"; };
741 1.2 martin option "encblkno8", exit, action { *(const char**)arg = "encblkno8"; };
742 1.2 martin
743 1.2 martin menu cgd_keygentype;
744 1.2 martin option "pkcs5_pbkdf2/sha1", exit, action { *(const char**)arg = "pkcs5_pbkdf2/sha1"; };
745 1.2 martin option "pkcs5_pbkdf2", exit, action { *(const char**)arg = "pkcs5_pbkdf2"; };
746 1.2 martin option "storedkey", exit, action { *(const char**)arg = "storedkey"; };
747 1.2 martin option "randomkey", exit, action { *(const char**)arg = "randomkey"; };
748 1.2 martin option "urandomkey", exit, action { *(const char**)arg = "urandomkey"; };
749 1.2 martin option "shell_cmd", exit, action { *(const char**)arg = "shell_cmd"; };
750 1.2 martin
751 1.2 martin menu cgd_verifytype;
752 1.2 martin option "none", exit, action { *(const char**)arg = "none"; };
753 1.2 martin option "disklabel", exit, action { *(const char**)arg = "disklabel"; };
754 1.2 martin option "ffs", exit, action { *(const char**)arg = "ffs"; };
755 1.2 martin option "re-enter", exit, action { *(const char**)arg = "re-enter"; };
756