diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2013-07-28 16:17:27 +0200 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2013-07-28 16:17:27 +0200 |
commit | 4c2cffbd316d468c9c9959a4fe695da2a535abe8 (patch) | |
tree | 211ce9ad6f481aeba2cc4ee8c240d608cc93ea9a /src/plugins/script | |
parent | 0e4eb69d3308fff112c5e2473c2e5ff9a60be22d (diff) | |
download | weechat-4c2cffbd316d468c9c9959a4fe695da2a535abe8.zip |
script: add info about things defined by script in the detailed view of script (/script show)
Diffstat (limited to 'src/plugins/script')
-rw-r--r-- | src/plugins/script/script-buffer.c | 234 |
1 files changed, 234 insertions, 0 deletions
diff --git a/src/plugins/script/script-buffer.c b/src/plugins/script/script-buffer.c index 65d5d09d1..e3f7d9f57 100644 --- a/src/plugins/script/script-buffer.c +++ b/src/plugins/script/script-buffer.c @@ -23,6 +23,7 @@ #include <stdio.h> #include <string.h> #include <time.h> +#include <libgen.h> #include "../weechat-plugin.h" #include "script.h" @@ -354,6 +355,208 @@ script_buffer_detail_label (const char *text, int max_length) } /* + * Gets pointer to a script (to the script managed by the appropriate plugin, + * for example python). + */ + +struct t_plugin_script * +script_buffer_get_script_pointer (struct t_script_repo *script, + struct t_hdata *hdata_script) +{ + char *filename, *ptr_base_name; + const char *ptr_filename; + void *ptr_script; + + ptr_script = weechat_hdata_get_list (hdata_script, "scripts"); + while (ptr_script) + { + ptr_filename = weechat_hdata_string (hdata_script, + ptr_script, "filename"); + if (ptr_filename) + { + filename = strdup (ptr_filename); + if (filename) + { + ptr_base_name = basename (filename); + if (strcmp (ptr_base_name, script->name_with_extension) == 0) + { + free (filename); + return ptr_script; + } + free (filename); + } + } + ptr_script = weechat_hdata_move (hdata_script, ptr_script, 1); + } + + /* script not found */ + return NULL; +} + +/* + * Gets a list with usage of the script (commands, config options...). + */ + +struct t_weelist * +script_buffer_get_script_usage (struct t_script_repo *script) +{ + struct t_weelist *list; + char hdata_name[128], str_option[256], str_info[1024]; + int config_files; + const char *ptr_name_hdata_callback, *type; + struct t_hdata *ptr_hdata_script, *ptr_hdata_callback; + struct t_hdata *ptr_hdata_config_file, *ptr_hdata_bar_item; + void *ptr_script, *ptr_callback; + struct t_config_file *ptr_config_file; + struct t_hook *ptr_hook; + struct t_gui_bar_item *ptr_bar_item; + struct t_infolist *infolist; + + list = weechat_list_new (); + + config_files = 0; + + snprintf (hdata_name, sizeof (hdata_name), + "%s_script", script_language[script->language]); + ptr_hdata_script = weechat_hdata_get (hdata_name); + if (!ptr_hdata_script) + goto end; + + ptr_script = script_buffer_get_script_pointer (script, ptr_hdata_script); + if (!ptr_script) + goto end; + + ptr_name_hdata_callback = weechat_hdata_get_var_hdata (ptr_hdata_script, + "callbacks"); + if (!ptr_name_hdata_callback) + goto end; + ptr_hdata_callback = weechat_hdata_get (ptr_name_hdata_callback); + if (!ptr_hdata_callback) + goto end; + + ptr_hdata_config_file = weechat_hdata_get ("config_file"); + ptr_hdata_bar_item = weechat_hdata_get ("bar_item"); + + ptr_callback = weechat_hdata_pointer (ptr_hdata_script, + ptr_script, + "callbacks"); + while (ptr_callback) + { + str_info[0] = '\0'; + ptr_config_file = weechat_hdata_pointer (ptr_hdata_callback, + ptr_callback, + "config_file"); + ptr_hook = weechat_hdata_pointer (ptr_hdata_callback, + ptr_callback, + "hook"); + ptr_bar_item = weechat_hdata_pointer (ptr_hdata_callback, + ptr_callback, + "bar_item"); + if (ptr_config_file) + { + snprintf (str_info, sizeof (str_info), + _("configuration file \"%s\" (options %s.*)"), + weechat_hdata_string (ptr_hdata_config_file, + ptr_config_file, + "filename"), + weechat_hdata_string (ptr_hdata_config_file, + ptr_config_file, + "name")); + config_files++; + } + else if (ptr_hook) + { + infolist = weechat_infolist_get ("hook", ptr_hook, NULL); + if (infolist) + { + if (weechat_infolist_next (infolist)) + { + type = weechat_infolist_string (infolist, "type"); + if (type) + { + if (strcmp (type, "command") == 0) + { + snprintf (str_info, sizeof (str_info), + _("command /%s"), + weechat_infolist_string (infolist, + "command")); + } + else if (strcmp (type, "completion") == 0) + { + snprintf (str_info, sizeof (str_info), + _("completion %%(%s)"), + weechat_infolist_string (infolist, + "completion_item")); + } + else if (strcmp (type, "info") == 0) + { + snprintf (str_info, sizeof (str_info), + "info \"%s\"", + weechat_infolist_string (infolist, + "info_name")); + } + else if (strcmp (type, "info_hashtable") == 0) + { + snprintf (str_info, sizeof (str_info), + "info_hashtable \"%s\"", + weechat_infolist_string (infolist, + "info_name")); + } + else if (strcmp (type, "infolist") == 0) + { + snprintf (str_info, sizeof (str_info), + "infolist \"%s\"", + weechat_infolist_string (infolist, + "infolist_name")); + } + } + } + weechat_infolist_free (infolist); + } + } + else if (ptr_bar_item) + { + snprintf (str_info, sizeof (str_info), + _("bar item \"%s\""), + weechat_hdata_string (ptr_hdata_bar_item, + ptr_bar_item, + "name")); + } + if (str_info[0]) + { + weechat_list_add (list, str_info, + WEECHAT_LIST_POS_END, NULL); + } + ptr_callback = weechat_hdata_move (ptr_hdata_callback, + ptr_callback, + 1); + } + +end: + snprintf (str_option, sizeof (str_option), + "plugins.var.%s.%s.*", + script_language[script->language], + weechat_hdata_string (ptr_hdata_script, ptr_script, "name")); + infolist = weechat_infolist_get ("option", NULL, str_option); + if (infolist) + { + if (weechat_infolist_next (infolist)) + { + snprintf (str_info, sizeof (str_info), + _("options %s%s%s"), + str_option, + (config_files > 0) ? " " : "", + (config_files > 0) ? _("(old options?)") : ""); + weechat_list_add (list, str_info, + WEECHAT_LIST_POS_END, NULL); + } + weechat_infolist_free (infolist); + } + + return list; +} + +/* * Displays detail on a script. */ @@ -369,6 +572,8 @@ script_buffer_display_detail_script (struct t_script_repo *script) N_("Min WeeChat"), N_("Max WeeChat"), NULL }; int i, length, max_length, line; + struct t_weelist *list; + struct t_weelist_item *ptr_item; max_length = 0; for (i = 0; labels[i]; i++) @@ -475,6 +680,35 @@ script_buffer_display_detail_script (struct t_script_repo *script) (script->max_weechat) ? script->max_weechat : "-"); line++; + if (script->status & SCRIPT_STATUS_RUNNING) + { + list = script_buffer_get_script_usage (script); + if (list) + { + line++; + weechat_printf_y (script_buffer, line + 1, + _("Script has defined:")); + i = 0; + ptr_item = weechat_list_get (list, 0); + while (ptr_item) + { + line++; + weechat_printf_y (script_buffer, line + 1, + " %s", weechat_list_string (ptr_item)); + ptr_item = weechat_list_next (ptr_item); + i++; + } + if (i == 0) + { + line++; + weechat_printf_y (script_buffer, line + 1, + " %s", _("(nothing)")); + } + line++; + weechat_list_free (list); + } + } + script_buffer_detail_script_last_line = line + 2; script_buffer_detail_script_line_diff = -1; } |