Ticket #1791: a nice dark skin created by Lee Bigelow.
[kaloumi3.git] / src / viewer / dialogs.c
blobedc178a8d62f579034d4a8d644c3b8cb2c79be52
1 /*
2 Internal file viewer for the Midnight Commander
3 Function for paint dialogs
5 Copyright (C) 1994, 1995, 1996, 1998, 1999, 2000, 2001, 2002, 2003,
6 2004, 2005, 2006, 2007, 2009 Free Software Foundation, Inc.
8 Written by: 1994, 1995, 1998 Miguel de Icaza
9 1994, 1995 Janne Kukonlehto
10 1995 Jakub Jelinek
11 1996 Joseph M. Hinkle
12 1997 Norbert Warmuth
13 1998 Pavel Machek
14 2004 Roland Illig <roland.illig@gmx.de>
15 2005 Roland Illig <roland.illig@gmx.de>
16 2009 Slava Zanko <slavazanko@google.com>
17 2009 Andrew Borodin <aborodin@vmail.ru>
18 2009 Ilia Maslakov <il.smind@gmail.com>
20 This file is part of the Midnight Commander.
22 The Midnight Commander is free software; you can redistribute it
23 and/or modify it under the terms of the GNU General Public License as
24 published by the Free Software Foundation; either version 2 of the
25 License, or (at your option) any later version.
27 The Midnight Commander is distributed in the hope that it will be
28 useful, but WITHOUT ANY WARRANTY; without even the implied warranty
29 of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
30 General Public License for more details.
32 You should have received a copy of the GNU General Public License
33 along with this program; if not, write to the Free Software
34 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
35 MA 02110-1301, USA.
38 #include <config.h>
40 #include <stdlib.h>
41 #include <sys/types.h>
43 #include "lib/global.h"
44 #include "lib/search.h"
45 #include "lib/strutil.h"
47 #include "src/wtools.h"
48 #include "src/history.h"
49 #include "src/charsets.h"
51 #include "internal.h"
53 /*** global variables ****************************************************************************/
55 mcview_search_options_t mcview_search_options = {
56 .type = MC_SEARCH_T_NORMAL,
57 .case_sens = FALSE,
58 .backwards = FALSE,
59 .whole_words = FALSE,
60 .all_codepages = FALSE
63 /*** file scope macro definitions ****************************************************************/
65 /*** file scope type declarations ****************************************************************/
67 /*** file scope variables ************************************************************************/
69 /*** file scope functions ************************************************************************/
71 /*** public functions ****************************************************************************/
73 /* --------------------------------------------------------------------------------------------- */
75 gboolean
76 mcview_dialog_search (mcview_t * view)
78 int SEARCH_DLG_MIN_HEIGHT = 12;
79 int SEARCH_DLG_HEIGHT_SUPPLY = 3;
80 int SEARCH_DLG_WIDTH = 58;
82 char *exp = NULL;
83 int qd_result;
85 size_t num_of_types;
86 gchar **list_of_types = mc_search_get_types_strings_array (&num_of_types);
87 int SEARCH_DLG_HEIGHT = SEARCH_DLG_MIN_HEIGHT + num_of_types - SEARCH_DLG_HEIGHT_SUPPLY;
89 QuickWidget quick_widgets[] = {
90 QUICK_BUTTON (6, 10, SEARCH_DLG_HEIGHT - 3, SEARCH_DLG_HEIGHT, N_("&Cancel"), B_CANCEL,
91 NULL),
92 QUICK_BUTTON (2, 10, SEARCH_DLG_HEIGHT - 3, SEARCH_DLG_HEIGHT, N_("&OK"), B_ENTER, NULL),
93 #ifdef HAVE_CHARSET
94 QUICK_CHECKBOX (SEARCH_DLG_WIDTH / 2 + 3, SEARCH_DLG_WIDTH, 8, SEARCH_DLG_HEIGHT,
95 N_("All charsets"), &mcview_search_options.all_codepages),
96 #endif
97 QUICK_CHECKBOX (SEARCH_DLG_WIDTH / 2 + 3, SEARCH_DLG_WIDTH, 7, SEARCH_DLG_HEIGHT,
98 N_("&Whole words"), &mcview_search_options.whole_words),
99 QUICK_CHECKBOX (SEARCH_DLG_WIDTH / 2 + 3, SEARCH_DLG_WIDTH, 6, SEARCH_DLG_HEIGHT,
100 N_("&Backwards"), &mcview_search_options.backwards),
101 QUICK_CHECKBOX (SEARCH_DLG_WIDTH / 2 + 3, SEARCH_DLG_WIDTH, 5, SEARCH_DLG_HEIGHT,
102 N_("case &Sensitive"), &mcview_search_options.case_sens),
103 QUICK_RADIO (3, SEARCH_DLG_WIDTH, 5, SEARCH_DLG_HEIGHT,
104 num_of_types, (const char **) list_of_types,
105 (int *) &mcview_search_options.type),
106 QUICK_INPUT (3, SEARCH_DLG_WIDTH, 3, SEARCH_DLG_HEIGHT,
107 INPUT_LAST_TEXT, SEARCH_DLG_WIDTH - 6, 0, MC_HISTORY_SHARED_SEARCH, &exp),
108 QUICK_LABEL (2, SEARCH_DLG_WIDTH, 2, SEARCH_DLG_HEIGHT, N_(" Enter search string:")),
109 QUICK_END
112 QuickDialog Quick_input = {
113 SEARCH_DLG_WIDTH, SEARCH_DLG_HEIGHT, -1, -1,
114 N_("Search"), "[Input Line Keys]",
115 quick_widgets, FALSE
118 qd_result = quick_dialog (&Quick_input);
119 g_strfreev (list_of_types);
121 if ((qd_result == B_CANCEL) || (exp == NULL) || (exp[0] == '\0'))
123 g_free (exp);
124 return FALSE;
127 #ifdef HAVE_CHARSET
129 GString *tmp = str_convert_to_input (exp);
131 if (tmp)
133 g_free (exp);
134 exp = g_string_free (tmp, FALSE);
137 #endif
139 g_free (view->last_search_string);
140 view->last_search_string = exp;
142 if (view->search_nroff_seq != NULL)
143 mcview_nroff_seq_free (&(view->search_nroff_seq));
145 if (view->search != NULL)
146 mc_search_free (view->search);
148 view->search = mc_search_new (view->last_search_string, -1);
149 view->search_nroff_seq = mcview_nroff_seq_new (view);
150 if (view->search != NULL)
152 view->search->search_type = mcview_search_options.type;
153 view->search->is_all_charsets = mcview_search_options.all_codepages;
154 view->search->is_case_sentitive = mcview_search_options.case_sens;
155 view->search->whole_words = mcview_search_options.whole_words;
156 view->search->search_fn = mcview_search_cmd_callback;
157 view->search->update_fn = mcview_search_update_cmd_callback;
160 return (view->search != NULL);
163 /* --------------------------------------------------------------------------------------------- */
165 gboolean
166 mcview_dialog_goto (mcview_t * view, off_t * offset)
168 typedef enum
170 MC_VIEW_GOTO_LINENUM = 0,
171 MC_VIEW_GOTO_PERCENT = 1,
172 MC_VIEW_GOTO_OFFSET_DEC = 2,
173 MC_VIEW_GOTO_OFFSET_HEX = 3
174 } mcview_goto_type_t;
176 const char *mc_view_goto_str[] = {
177 N_("&Line number (decimal)"),
178 N_("Pe&rcents"),
179 N_("&Decimal offset"),
180 N_("He&xadecimal offset")
183 const int goto_dlg_height = 12;
184 int goto_dlg_width = 40;
186 static mcview_goto_type_t current_goto_type = MC_VIEW_GOTO_LINENUM;
188 size_t i;
190 size_t num_of_types = sizeof (mc_view_goto_str) / sizeof (mc_view_goto_str[0]);
191 char *exp = NULL;
192 int qd_result;
193 gboolean res = FALSE;
195 QuickWidget quick_widgets[] = {
196 QUICK_BUTTON (6, 10, goto_dlg_height - 3, goto_dlg_height, N_("&Cancel"), B_CANCEL, NULL),
197 QUICK_BUTTON (2, 10, goto_dlg_height - 3, goto_dlg_height, N_("&OK"), B_ENTER, NULL),
198 QUICK_RADIO (3, goto_dlg_width, 4, goto_dlg_height,
199 num_of_types, (const char **) mc_view_goto_str, (int *) &current_goto_type),
200 QUICK_INPUT (3, goto_dlg_width, 2, goto_dlg_height,
201 INPUT_LAST_TEXT, goto_dlg_width - 6, 0, MC_HISTORY_VIEW_GOTO, &exp),
202 QUICK_END
205 QuickDialog Quick_input = {
206 goto_dlg_width, goto_dlg_height, -1, -1,
207 N_("Goto"), "[Input Line Keys]",
208 quick_widgets, FALSE
211 #ifdef ENABLE_NLS
212 for (i = 0; i < num_of_types; i++)
213 mc_view_goto_str[i] = _(mc_view_goto_str[i]);
215 quick_widgets[0].u.button.text = _(quick_widgets[0].u.button.text);
216 quick_widgets[1].u.button.text = _(quick_widgets[1].u.button.text);
217 #endif
219 /* calculate widget coordinates */
221 int b0_len, b1_len, len;
222 const int button_gap = 2;
224 /* preliminary dialog width */
225 goto_dlg_width = max (goto_dlg_width, str_term_width1 (Quick_input.title) + 4);
227 /* length of radiobuttons */
228 for (i = 0; i < num_of_types; i++)
229 goto_dlg_width = max (goto_dlg_width, str_term_width1 (mc_view_goto_str[i]) + 10);
231 /* length of buttons */
232 b0_len = str_term_width1 (quick_widgets[0].u.button.text) + 3;
233 b1_len = str_term_width1 (quick_widgets[1].u.button.text) + 5; /* default button */
234 len = b0_len + b1_len + button_gap * 2;
236 /* dialog width */
237 Quick_input.xlen = max (goto_dlg_width, len + 6);
239 /* correct widget coordinates */
240 for (i = sizeof (quick_widgets) / sizeof (quick_widgets[0]); i > 0; i--)
241 quick_widgets[i - 1].x_divisions = Quick_input.xlen;
243 /* input length */
244 quick_widgets[3].u.input.len = Quick_input.xlen - 6;
246 /* button positions */
247 quick_widgets[1].relative_x = Quick_input.xlen / 2 - len / 2;
248 quick_widgets[0].relative_x = quick_widgets[1].relative_x + b1_len + button_gap;
251 /* run dialog */
252 qd_result = quick_dialog (&Quick_input);
254 *offset = -1;
256 /* check input line value */
257 if ((qd_result != B_CANCEL) && (exp != NULL) && (exp[0] != '\0'))
259 int base = (current_goto_type == MC_VIEW_GOTO_OFFSET_HEX) ? 16 : 10;
260 off_t addr;
261 char *error;
263 res = TRUE;
265 addr = strtoll (exp, &error, base);
266 if ((*error == '\0') && (addr >= 0))
268 switch (current_goto_type)
270 case MC_VIEW_GOTO_LINENUM:
271 mcview_coord_to_offset (view, offset, addr, 0);
272 break;
273 case MC_VIEW_GOTO_PERCENT:
274 if (addr > 100)
275 addr = 100;
276 *offset = addr * mcview_get_filesize (view) / 100;
277 break;
278 case MC_VIEW_GOTO_OFFSET_DEC:
279 *offset = addr;
280 break;
281 case MC_VIEW_GOTO_OFFSET_HEX:
282 *offset = addr;
283 break;
284 default:
285 break;
287 *offset = mcview_bol (view, *offset);
291 g_free (exp);
292 return res;