elinks-0.11.4rc0
[elinks.git] / src / dialogs / info.c
blob1033942fed10009994c964ec9f4978dd828efead
1 /* Info dialogs */
3 #ifdef HAVE_CONFIG_H
4 #include "config.h"
5 #endif
7 #include <stdio.h>
8 #include <stdlib.h>
9 #include <string.h>
10 #ifdef HAVE_UNISTD_H
11 #include <unistd.h>
12 #endif
14 #include "elinks.h"
16 #include "bfu/dialog.h"
17 #include "cache/cache.h"
18 #include "config/kbdbind.h"
19 #include "config/options.h"
20 #include "dialogs/info.h"
21 #include "document/html/renderer.h"
22 #include "intl/gettext/libintl.h"
23 #include "main/select.h"
24 #include "main/timer.h"
25 #include "main/version.h"
26 #include "network/connection.h"
27 #include "session/session.h"
28 #include "terminal/terminal.h"
29 #include "util/conv.h"
30 #ifdef DEBUG_MEMLEAK
31 #include "util/memdebug.h"
32 #endif
33 #include "util/memlist.h"
34 #include "util/memory.h"
35 #include "util/string.h"
37 void
38 menu_about(struct terminal *term, void *xxx, void *xxxx)
40 info_box(term, MSGBOX_FREE_TEXT,
41 N_("About"), ALIGN_CENTER,
42 get_dyn_full_version(term, 1));
45 struct keys_toggle_info {
46 struct terminal *term;
47 int toggle;
50 static void
51 push_toggle_keys_display_button(void *data)
53 struct keys_toggle_info *info = data;
55 menu_keys(info->term, (void *) (long) !info->toggle, NULL);
58 void
59 menu_keys(struct terminal *term, void *d_, void *xxx)
61 int d = (long) d_;
63 /* We scale by main mapping because it has the most actions */
64 action_id_T action_ids[MAIN_ACTIONS] = {
65 ACT_MAIN_MENU,
66 ACT_MAIN_QUIT,
67 ACT_MAIN_MOVE_LINK_NEXT,
68 ACT_MAIN_MOVE_LINK_PREV,
69 ACT_MAIN_SCROLL_DOWN,
70 ACT_MAIN_SCROLL_UP,
71 ACT_MAIN_SCROLL_LEFT,
72 ACT_MAIN_SCROLL_RIGHT,
73 ACT_MAIN_HISTORY_MOVE_BACK,
74 ACT_MAIN_GOTO_URL,
75 ACT_MAIN_GOTO_URL_CURRENT,
76 ACT_MAIN_DOCUMENT_INFO,
77 ACT_MAIN_HEADER_INFO,
78 ACT_MAIN_SEARCH,
79 ACT_MAIN_SEARCH_BACK,
80 ACT_MAIN_FIND_NEXT,
81 ACT_MAIN_FIND_NEXT_BACK,
82 ACT_MAIN_LINK_FOLLOW,
83 ACT_MAIN_LINK_DOWNLOAD,
84 ACT_MAIN_TOGGLE_HTML_PLAIN,
86 ACT_MAIN_NONE,
88 struct string keys;
89 struct keys_toggle_info *info;
91 info = mem_calloc(1, sizeof(*info));
93 if (!info || !init_string(&keys)) {
94 mem_free_if(info);
95 return;
98 info->term = term;
99 info->toggle = d;
101 if (info->toggle) {
102 action_id_T action_id;
103 enum keymap_id keymap_id;
105 for (action_id = 0; action_id < MAIN_ACTIONS - 1; action_id++) {
106 action_ids[action_id] = action_id + 1;
109 for (keymap_id = 0; keymap_id < KEYMAP_MAX; keymap_id++) {
110 add_actions_to_string(&keys, action_ids, keymap_id, term);
111 if (keymap_id + 1 < KEYMAP_MAX)
112 add_to_string(&keys, "\n\n");
114 /* Just a little reminder that the following code takes
115 * the easy way. */
116 assert(MAIN_ACTIONS > EDIT_ACTIONS);
117 assert(EDIT_ACTIONS > MENU_ACTIONS);
119 if (keymap_id == KEYMAP_MAIN) {
120 action_ids[EDIT_ACTIONS] = ACT_EDIT_NONE;
121 } else if (keymap_id == KEYMAP_EDIT) {
122 action_ids[MENU_ACTIONS] = ACT_MENU_NONE;
125 } else {
126 add_actions_to_string(&keys, action_ids, KEYMAP_MAIN, term);
129 msg_box(term, getml(info, NULL), MSGBOX_FREE_TEXT | MSGBOX_SCROLLABLE,
130 N_("Keys"), ALIGN_LEFT,
131 keys.source,
132 info, 2,
133 N_("~OK"), NULL, B_ENTER | B_ESC,
134 N_("~Toggle display"), push_toggle_keys_display_button, B_ENTER);
137 void
138 menu_copying(struct terminal *term, void *xxx, void *xxxx)
140 info_box(term, MSGBOX_FREE_TEXT,
141 N_("Copying"), ALIGN_CENTER,
142 msg_text(term, N_("ELinks %s\n"
143 "\n"
144 "(C) 1999 - 2002 Mikulas Patocka\n"
145 "(C) 2001 - 2004 Petr Baudis\n"
146 "(C) 2002 - 2008 Jonas Fonseca\n"
147 "and others\n"
148 "\n"
149 "This program is free software; you can redistribute it "
150 "and/or modify it under the terms of the GNU General Public "
151 "License as published by the Free Software Foundation, "
152 "specifically version 2 of the License."),
153 VERSION_STRING));
157 static unsigned char *
158 get_resource_info(struct terminal *term, void *data)
160 struct string info;
161 long val;
162 unsigned longlong bigval;
164 if (!init_string(&info))
165 return NULL;
167 #define val_add(text) \
168 add_format_to_string(&info, text, val);
170 add_to_string(&info, _("Resources", term));
171 add_to_string(&info, ": ");
173 val = get_file_handles_count();
174 val_add(n_("%ld handle", "%ld handles", val, term));
175 add_to_string(&info, ", ");
177 val = get_timers_count();
178 val_add(n_("%ld timer", "%ld timers", val, term));
179 add_to_string(&info, ".\n");
181 add_to_string(&info, _("Connections", term));
182 add_to_string(&info, ": ");
184 val = get_connections_count();
185 val_add(n_("%ld connection", "%ld connections", val, term));
186 add_to_string(&info, ", ");
188 val = get_connections_connecting_count();
189 val_add(n_("%ld connecting", "%ld connecting", val, term));
190 add_to_string(&info, ", ");
192 val = get_connections_transfering_count();
193 val_add(n_("%ld transferring", "%ld transferring", val, term));
194 add_to_string(&info, ", ");
196 val = get_keepalive_connections_count();
197 val_add(n_("%ld keepalive", "%ld keepalive", val, term));
198 add_to_string(&info, ".\n");
200 add_to_string(&info, _("Memory cache", term));
201 add_to_string(&info, ": ");
203 /* What about just using Kibi/Mebi representation here? --jonas */
204 bigval = get_cache_size();
205 add_format_to_string(&info, n_("%ld byte", "%ld bytes", bigval, term), bigval);
206 add_to_string(&info, ", ");
208 val = get_cache_entry_count();
209 val_add(n_("%ld file", "%ld files", val, term));
210 add_to_string(&info, ", ");
212 val = get_cache_entry_used_count();
213 val_add(n_("%ld in use", "%ld in use", val, term));
214 add_to_string(&info, ", ");
216 val = get_cache_entry_loading_count();
217 val_add(n_("%ld loading", "%ld loading", val, term));
218 add_to_string(&info, ".\n");
220 add_to_string(&info, _("Document cache", term));
221 add_to_string(&info, ": ");
223 val = get_format_cache_size();
224 val_add(n_("%ld formatted", "%ld formatted", val, term));
225 add_to_string(&info, ", ");
227 val = get_format_cache_used_count();
228 val_add(n_("%ld in use", "%ld in use", val, term));
229 add_to_string(&info, ", ");
231 val = get_format_cache_refresh_count();
232 val_add(n_("%ld refreshing", "%ld refreshing", val, term));
233 add_to_string(&info, ".\n");
235 add_to_string(&info, _("Interlinking", term));
236 add_to_string(&info, ": ");
237 if (term->master)
238 add_to_string(&info, _("master terminal", term));
239 else
240 add_to_string(&info, _("slave terminal", term));
241 add_to_string(&info, ", ");
243 val = list_size(&terminals);
244 val_add(n_("%ld terminal", "%ld terminals", val, term));
245 add_to_string(&info, ", ");
247 val = list_size(&sessions);
248 val_add(n_("%ld session", "%ld sessions", val, term));
249 add_char_to_string(&info, '.');
251 #ifdef DEBUG_MEMLEAK
252 add_char_to_string(&info, '\n');
253 add_to_string(&info, _("Memory allocated", term));
254 add_to_string(&info, ": ");
256 val = mem_stats.amount;
257 val_add(n_("%ld byte", "%ld bytes", val, term));
258 add_to_string(&info, ", ");
260 val = mem_stats.true_amount - mem_stats.amount;
261 val_add(n_("%ld byte overhead", "%ld bytes overhead", val, term));
263 add_format_to_string(&info, " (%0.2f%%).",
264 (double) (mem_stats.true_amount - mem_stats.amount) / (double) mem_stats.amount * 100);
265 #endif /* DEBUG_MEMLEAK */
267 #undef val_add
269 return info.source;
272 void
273 resource_info(struct terminal *term)
275 refreshed_msg_box(term, 0, N_("Resources"), ALIGN_LEFT,
276 get_resource_info, NULL);