2 * Copyright (c) 2011 Nathan Whitehorn
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 #include "diskeditor.h"
38 print_partedit_item(WINDOW *partitions, struct partedit_item *items,
39 int item, int nscroll, int selected)
41 chtype attr = A_NORMAL;
43 int y = item - nscroll + 1;
45 wattrset(partitions, selected ? item_selected_attr : item_attr);
46 wmove(partitions, y, MARGIN + items[item].indentation*2);
47 dlg_print_text(partitions, items[item].name, 10, &attr);
48 wmove(partitions, y, 17);
49 wattrset(partitions, item_attr);
51 humanize_number(sizetext, 7, items[item].size, "B", HN_AUTOSCALE,
53 dlg_print_text(partitions, sizetext, 8, &attr);
54 wmove(partitions, y, 25);
55 dlg_print_text(partitions, items[item].type, 15, &attr);
56 wmove(partitions, y, 40);
57 if (items[item].mountpoint != NULL)
58 dlg_print_text(partitions, items[item].mountpoint, 8, &attr);
62 diskeditor_show(const char *title, const char *cprompt,
63 struct partedit_item *items, int nitems, int *selected, int *nscroll)
65 WINDOW *dialog, *partitions;
67 const char *buttons[] =
68 { "Create", "Delete", "Modify", "Revert", "Auto", "Finish", NULL };
69 const char *help_text[] = {
70 "Add a new partition", "Delete selected partition or partitions",
71 "Change partition type or mountpoint",
72 "Revert changes to disk setup", "Use guided partitioning tool",
73 "Exit partitioner (will ask whether to save changes)", NULL };
76 int height, width, min_width;
77 int partlist_height, partlist_width, min_partlist_width;
80 int cur_button = 0, cur_part = 0;
81 int result = DLG_EXIT_UNKNOWN;
83 static DLG_KEYS_BINDING binding[] = {
85 DLG_KEYS_DATA( DLGK_ENTER, ' ' ),
86 DLG_KEYS_DATA( DLGK_ITEM_NEXT, KEY_DOWN ),
87 DLG_KEYS_DATA( DLGK_ITEM_PREV, KEY_UP ),
88 DLG_KEYS_DATA( DLGK_FIELD_NEXT, KEY_RIGHT ),
89 DLG_KEYS_DATA( DLGK_FIELD_NEXT, TAB ),
90 DLG_KEYS_DATA( DLGK_FIELD_PREV, KEY_BTAB ),
91 DLG_KEYS_DATA( DLGK_FIELD_PREV, KEY_LEFT ),
98 * Set up editor window.
100 prompt = dlg_strclone(cprompt);
104 partlist_height = 10;
105 min_partlist_width = 0;
106 dlg_tab_correct_str(prompt);
107 dlg_button_layout(buttons, &min_width);
108 dlg_auto_size(title, prompt, &height, &width, 2, min_width);
109 height += partlist_height;
110 partlist_width = width - 2*MARGIN;
111 dlg_print_size(height, width);
112 dlg_ctl_size(height, width);
114 x = dlg_box_x_ordinate(width);
115 y = dlg_box_y_ordinate(height);
117 dialog = dlg_new_window(height, width, y, x);
118 dlg_register_window(dialog, "diskeditorbox", binding);
119 dlg_register_buttons(dialog, "diskeditorbox", buttons);
121 dlg_draw_box(dialog, 0, 0, height, width, dialog_attr, border_attr);
122 dlg_draw_bottom_box(dialog);
123 dlg_draw_title(dialog, title);
124 wattrset(dialog, dialog_attr);
126 /* Partition list sub-window */
127 partitions = dlg_sub_window(dialog, partlist_height, partlist_width,
129 dlg_register_window(partitions, "partlist", binding);
130 dlg_register_buttons(partitions, "partlist", buttons);
131 wattrset(partitions, menubox_attr);
133 dlg_item_help(help_text[cur_button]);
134 dlg_draw_buttons(dialog, height - 2*MARGIN, 0, buttons,
135 cur_button, FALSE, width);
136 dlg_print_autowrap(dialog, prompt, height, width);
138 if (selected != NULL)
139 cur_part = *selected;
141 cur_scroll = *nscroll;
142 if (cur_part - cur_scroll >= partlist_height - 2 ||
143 cur_part - cur_scroll < 0)
144 cur_scroll = cur_part;
147 dlg_draw_box(dialog, 3, 1, partlist_height, partlist_width,
148 menubox_border_attr, menubox_attr);
149 for (i = cur_scroll; i < MIN(cur_scroll + partlist_height - 2, nitems);
151 print_partedit_item(partitions, items, i, cur_scroll,
153 if (nitems > partlist_height - 2)
154 dlg_draw_arrows(partitions, cur_scroll > 0,
155 nitems > cur_scroll + partlist_height - 2,
156 partlist_width - 5, 0, partlist_height - 1);
157 wrefresh(partitions);
159 while (result == DLG_EXIT_UNKNOWN) {
160 key = dlg_mouse_wgetch(dialog, &fkey);
161 if ((i = dlg_char_to_button(key, buttons)) >= 0) {
163 dlg_item_help(help_text[cur_button]);
164 dlg_draw_buttons(dialog, height - 2*MARGIN, 0, buttons,
165 cur_button, FALSE, width);
173 case DLGK_FIELD_NEXT:
174 cur_button = dlg_next_button(buttons, cur_button);
177 dlg_item_help(help_text[cur_button]);
178 dlg_draw_buttons(dialog, height - 2*MARGIN, 0, buttons,
179 cur_button, FALSE, width);
181 case DLGK_FIELD_PREV:
182 cur_button = dlg_prev_button(buttons, cur_button);
185 dlg_item_help(help_text[cur_button]);
186 dlg_draw_buttons(dialog, height - 2*MARGIN, 0, buttons,
187 cur_button, FALSE, width);
190 if (cur_part == nitems - 1)
191 break; /* End of list */
193 /* Deselect old item */
194 print_partedit_item(partitions, items, cur_part,
196 /* Select new item */
198 if (cur_part - cur_scroll >= partlist_height - 2) {
199 cur_scroll = cur_part;
202 print_partedit_item(partitions, items, cur_part,
204 wrefresh(partitions);
208 break; /* Start of list */
210 /* Deselect old item */
211 print_partedit_item(partitions, items, cur_part,
213 /* Select new item */
215 if (cur_part - cur_scroll < 0) {
216 cur_scroll = cur_part;
219 print_partedit_item(partitions, items, cur_part,
221 wrefresh(partitions);
224 cur_scroll += (partlist_height - 2);
225 if (cur_scroll + partlist_height - 2 >= nitems)
226 cur_scroll = nitems - (partlist_height - 2);
229 if (cur_part < cur_scroll)
230 cur_part = cur_scroll;
233 cur_scroll -= (partlist_height - 2);
236 if (cur_part >= cur_scroll + partlist_height - 2)
237 cur_part = cur_scroll;
239 case DLGK_PAGE_FIRST:
241 cur_part = cur_scroll;
244 cur_scroll = nitems - (partlist_height - 2);
247 cur_part = cur_scroll;
252 if (is_DLGK_MOUSE(key)) {
253 cur_button = key - M_EVENT;
254 dlg_item_help(help_text[cur_button]);
255 dlg_draw_buttons(dialog, height - 2*MARGIN, 0,
256 buttons, cur_button, FALSE, width);
264 if (selected != NULL)
265 *selected = cur_part;
267 *nscroll = cur_scroll;
269 dlg_del_window(partitions);
270 dlg_del_window(dialog);
271 dlg_mouse_free_regions();