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"
31 #include "util/memdebug.h"
33 #include "util/memlist.h"
34 #include "util/memory.h"
35 #include "util/string.h"
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
;
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
);
59 menu_keys(struct terminal
*term
, void *d_
, void *xxx
)
63 /* We scale by main mapping because it has the most actions */
64 action_id_T action_ids
[MAIN_ACTIONS
] = {
67 ACT_MAIN_MOVE_LINK_NEXT
,
68 ACT_MAIN_MOVE_LINK_PREV
,
72 ACT_MAIN_SCROLL_RIGHT
,
73 ACT_MAIN_HISTORY_MOVE_BACK
,
75 ACT_MAIN_GOTO_URL_CURRENT
,
76 ACT_MAIN_DOCUMENT_INFO
,
81 ACT_MAIN_FIND_NEXT_BACK
,
83 ACT_MAIN_LINK_DOWNLOAD
,
84 ACT_MAIN_TOGGLE_HTML_PLAIN
,
89 struct keys_toggle_info
*info
;
91 info
= mem_calloc(1, sizeof(*info
));
93 if (!info
|| !init_string(&keys
)) {
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
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
;
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
,
133 N_("~OK"), NULL
, B_ENTER
| B_ESC
,
134 N_("~Toggle display"), push_toggle_keys_display_button
, B_ENTER
);
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"
144 "(C) 1999 - 2002 Mikulas Patocka\n"
145 "(C) 2001 - 2004 Petr Baudis\n"
146 "(C) 2002 - 2005 Jonas Fonseca\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."),
157 static unsigned char *
158 get_resource_info(struct terminal
*term
, void *data
)
162 unsigned longlong bigval
;
164 if (!init_string(&info
))
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 val_add(n_("%ld byte", "%ld bytes", val
, term
));
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
, ": ");
238 add_to_string(&info
, _("master terminal", term
));
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
, '.');
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 */
273 resource_info(struct terminal
*term
)
275 refreshed_msg_box(term
, 0, N_("Resources"), ALIGN_LEFT
,
276 get_resource_info
, NULL
);