diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2023-07-08 13:26:44 +0200 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2023-07-08 13:31:36 +0200 |
commit | 89137552a73ef64e9f05ae1a5cb83a0fea474abf (patch) | |
tree | 7e54ca552bb3c023419fd9d32e9091734c64d038 /src | |
parent | 5b2cf75f6ea7a5b6ad2a8af14bb1a3570148835f (diff) | |
download | weechat-89137552a73ef64e9f05ae1a5cb83a0fea474abf.zip |
core: display focus hashtable for debug even if no key is matching
Diffstat (limited to 'src')
-rw-r--r-- | src/gui/gui-key.c | 56 |
1 files changed, 38 insertions, 18 deletions
diff --git a/src/gui/gui-key.c b/src/gui/gui-key.c index 1744f21d9..2085c5fe5 100644 --- a/src/gui/gui-key.c +++ b/src/gui/gui-key.c @@ -2003,6 +2003,31 @@ gui_key_focus_matching (struct t_gui_key *key, } /* + * Displays focus hashtable (for debug). + */ + +void +gui_key_focus_display_hashtable (struct t_hashtable *hashtable) +{ + struct t_weelist *list_keys; + struct t_weelist_item *ptr_item; + + gui_chat_printf (NULL, _("Hashtable focus:")); + list_keys = hashtable_get_list_keys (hashtable); + if (list_keys) + { + for (ptr_item = list_keys->items; ptr_item; + ptr_item = ptr_item->next_item) + { + gui_chat_printf (NULL, " %s: \"%s\"", + ptr_item->data, + hashtable_get (hashtable, ptr_item->data)); + } + weelist_free (list_keys); + } +} + +/* * Runs command according to focus. * * Returns: @@ -2020,8 +2045,6 @@ gui_key_focus_command (const char *key, int context, char *command, **commands; const char *str_buffer; struct t_hashtable *hashtable; - struct t_weelist *list_keys; - struct t_weelist_item *ptr_item; struct t_gui_buffer *ptr_buffer; debug = 0; @@ -2088,24 +2111,10 @@ gui_key_focus_command (const char *key, int context, gui_input_delete_line (gui_current_window->buffer); } - if (debug > 1) - { - gui_chat_printf (NULL, _("Hashtable focus:")); - list_keys = hashtable_get_list_keys (hashtable); - if (list_keys) - { - for (ptr_item = list_keys->items; ptr_item; - ptr_item = ptr_item->next_item) - { - gui_chat_printf (NULL, " %s: \"%s\"", - ptr_item->data, - hashtable_get (hashtable, ptr_item->data)); - } - weelist_free (list_keys); - } - } if (debug) { + if (debug > 1) + gui_key_focus_display_hashtable (hashtable); gui_chat_printf (NULL, _("Command for key: \"%s\""), ptr_key->command); } @@ -2156,6 +2165,17 @@ gui_key_focus_command (const char *key, int context, return 1; } + if (debug > 1) + { + hashtable = hook_focus_get_data (hashtable_focus[0], + hashtable_focus[1]); + if (hashtable) + { + gui_key_focus_display_hashtable (hashtable); + hashtable_free (hashtable); + } + } + return 0; } |