summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2007-12-02 18:02:18 +0100
committerSebastien Helleu <flashcode@flashtux.org>2007-12-02 18:02:18 +0100
commitfab33dc4df8dfd717012f046987b138e0af5b22f (patch)
tree604577ae7586baa19c2d9f282edb7b875d481c72
parent5c579ec3b88e61a4f6f61e7dc8cbf9621a1ec2f5 (diff)
downloadweechat-fab33dc4df8dfd717012f046987b138e0af5b22f.zip
Added config files management in plugins API
-rw-r--r--src/core/wee-config-file.c45
-rw-r--r--src/core/wee-config-file.h18
-rw-r--r--src/core/wee-config.c12
-rw-r--r--src/plugins/demo/demo.c4
-rw-r--r--src/plugins/plugin-api.c416
-rw-r--r--src/plugins/plugin-api.h30
-rw-r--r--src/plugins/plugin-config.c7
-rw-r--r--src/plugins/plugin-list.c10
-rw-r--r--src/plugins/plugin-list.h6
-rw-r--r--src/plugins/plugin.c2
-rw-r--r--src/plugins/weechat-plugin.h259
11 files changed, 532 insertions, 277 deletions
diff --git a/src/core/wee-config-file.c b/src/core/wee-config-file.c
index 572de2142..4e4360b73 100644
--- a/src/core/wee-config-file.c
+++ b/src/core/wee-config-file.c
@@ -45,7 +45,7 @@ struct t_config_file *last_config_file = NULL;
*/
struct t_config_file *
-config_file_new (char *filename)
+config_file_new (void *plugin, char *filename)
{
struct t_config_file *new_config_file;
@@ -55,6 +55,7 @@ config_file_new (char *filename)
new_config_file = (struct t_config_file *)malloc (sizeof (struct t_config_file));
if (new_config_file)
{
+ new_config_file->plugin = plugin;
new_config_file->filename = strdup (filename);
new_config_file->file = NULL;
new_config_file->sections = NULL;
@@ -78,9 +79,9 @@ config_file_new (char *filename)
struct t_config_section *
config_file_new_section (struct t_config_file *config_file, char *name,
- void (*callback_read)(struct t_config_file *, char *, char *),
- void (*callback_write)(struct t_config_file *),
- void (*callback_write_default)(struct t_config_file *))
+ void (*callback_read)(void *, char *, char *),
+ void (*callback_write)(void *),
+ void (*callback_write_default)(void *))
{
struct t_config_section *new_section;
@@ -393,6 +394,42 @@ config_file_search_option (struct t_config_file *config_file,
}
/*
+ * config_file_option_valid_for_plugin: check if an option pointer exists for a plugin
+ * return 1 if option exists for plugin
+ * 0 if option is not found for plugin
+ */
+
+int
+config_file_option_valid_for_plugin (void *plugin,
+ struct t_config_option *option)
+{
+ struct t_config_file *ptr_config;
+ struct t_config_section *ptr_section;
+ struct t_config_option *ptr_option;
+
+ for (ptr_config = config_files; ptr_config;
+ ptr_config = ptr_config->next_config)
+ {
+ if (ptr_config->plugin == (struct t_weechat_plugin *)plugin)
+ {
+ for (ptr_section = ptr_config->sections; ptr_section;
+ ptr_section = ptr_section->next_section)
+ {
+ for (ptr_option = ptr_section->options; ptr_option;
+ ptr_option = ptr_option->next_option)
+ {
+ if (ptr_option == option)
+ return 1;
+ }
+ }
+ }
+ }
+
+ /* option not found */
+ return 0;
+}
+
+/*
* config_file_string_boolean_value: return boolean value of string
* return -1 if error
*/
diff --git a/src/core/wee-config-file.h b/src/core/wee-config-file.h
index 9254cc11c..b0e852452 100644
--- a/src/core/wee-config-file.h
+++ b/src/core/wee-config-file.h
@@ -37,6 +37,7 @@
struct t_config_file
{
+ struct t_weechat_plugin *plugin; /* plugin which created this cfg */
char *filename; /* config filename (without path)*/
FILE *file; /* file pointer */
struct t_config_section *sections; /* config sections */
@@ -49,12 +50,11 @@ struct t_config_section
{
char *name; /* section name */
void (*callback_read) /* called when unknown option */
- (struct t_config_file *, /* is read from config file */
- char *, char *);
+ (void *, char *, char *); /* is read from config file */
void (*callback_write) /* called to write special */
- (struct t_config_file *); /* options in config file */
+ (void *); /* options in config file */
void (*callback_write_default) /* called to write default */
- (struct t_config_file *); /* options in config file */
+ (void *); /* options in config file */
struct t_config_option *options; /* options in section */
struct t_config_option *last_option; /* last option in section */
struct t_config_section *prev_section; /* link to previous section */
@@ -84,12 +84,12 @@ struct t_config_option
struct t_config_option *next_option; /* link to next option */
};
-extern struct t_config_file *config_file_new (char *);
+extern struct t_config_file *config_file_new (void *, char *);
extern struct t_config_section *config_file_new_section (struct t_config_file *,
char *,
- void (*)(struct t_config_file *, char *, char *),
- void (*)(struct t_config_file *),
- void (*)(struct t_config_file *));
+ void (*)(void *, char *, char *),
+ void (*)(void *),
+ void (*)(void *));
extern struct t_config_section *config_file_search_section (struct t_config_file *,
char *);
extern struct t_config_option *config_file_new_option_boolean (struct t_config_section *,
@@ -117,6 +117,8 @@ extern struct t_config_option *config_file_new_option_color (struct t_config_sec
extern struct t_config_option *config_file_search_option (struct t_config_file *,
struct t_config_section *,
char *);
+extern int config_file_option_valid_for_plugin (void *, struct t_config_option *);
+extern int config_file_string_boolean_value (char *);
extern int config_file_option_set (struct t_config_option *, char *);
extern int config_file_option_reset (struct t_config_option *);
diff --git a/src/core/wee-config.c b/src/core/wee-config.c
index e8fb7fe69..ba599f13b 100644
--- a/src/core/wee-config.c
+++ b/src/core/wee-config.c
@@ -324,7 +324,7 @@ config_change_nicks_colors ()
*/
void
-config_weechat_read_alias (struct t_config_file *config_file,
+config_weechat_read_alias (void *config_file,
char *option_name, char *value)
{
/* make C compiler happy */
@@ -343,7 +343,7 @@ config_weechat_read_alias (struct t_config_file *config_file,
*/
void
-config_weechat_read_key (struct t_config_file *config_file,
+config_weechat_read_key (void *config_file,
char *option_name, char *value)
{
/* make C compiler happy */
@@ -368,7 +368,7 @@ config_weechat_read_key (struct t_config_file *config_file,
*/
void
-config_weechat_write_alias (struct t_config_file *config_file)
+config_weechat_write_alias (void *config_file)
{
struct alias *ptr_alias;
char *string;
@@ -396,7 +396,7 @@ config_weechat_write_alias (struct t_config_file *config_file)
*/
void
-config_weechat_write_alias_default_values (struct t_config_file *config_file)
+config_weechat_write_alias_default_values (void *config_file)
{
config_file_write_line (config_file, "SAY", "\"msg *\"");
config_file_write_line (config_file, "BYE", "\"quit\"");
@@ -431,7 +431,7 @@ config_weechat_write_alias_default_values (struct t_config_file *config_file)
*/
void
-config_weechat_write_keys (struct t_config_file *config_file)
+config_weechat_write_keys (void *config_file)
{
t_gui_key *ptr_key;
char *expanded_name, *function_name, *string;
@@ -493,7 +493,7 @@ config_weechat_init ()
{
struct t_config_section *section;
- weechat_config = config_file_new (WEECHAT_CONFIG_FILENAME);
+ weechat_config = config_file_new (NULL, WEECHAT_CONFIG_FILENAME);
if (weechat_config)
{
/* look */
diff --git a/src/plugins/demo/demo.c b/src/plugins/demo/demo.c
index 6797e5afc..1df07869c 100644
--- a/src/plugins/demo/demo.c
+++ b/src/plugins/demo/demo.c
@@ -141,8 +141,8 @@ demo_print_list (void *list, char *item_name)
case 'i':
weechat_printf (NULL, " %s: %d",
argv[j] + 2,
- weechat_list_int (list,
- argv[j] + 2));
+ weechat_list_integer (list,
+ argv[j] + 2));
break;
case 's':
weechat_printf (NULL, " %s: %s",
diff --git a/src/plugins/plugin-api.c b/src/plugins/plugin-api.c
index 1dbb9372d..a95435bdb 100644
--- a/src/plugins/plugin-api.c
+++ b/src/plugins/plugin-api.c
@@ -254,6 +254,276 @@ plugin_api_exec_on_files (struct t_weechat_plugin *plugin, char *directory,
}
/*
+ * plugin_api_config_new: create new config file structure
+ */
+
+struct t_config_file *
+plugin_api_config_new (struct t_weechat_plugin *plugin, char *filename)
+{
+ return config_file_new (plugin, filename);
+}
+
+/*
+ * plugin_api_config_new_section: create new section in a config
+ */
+
+struct t_config_section *
+plugin_api_config_new_section (struct t_weechat_plugin *plugin,
+ void *config_file, char *name,
+ void (*callback_read)(void *, char *, char *),
+ void (*callback_write)(void *),
+ void (*callback_write_default)(void *))
+{
+ /* make C compiler happy */
+ (void) plugin;
+
+ return config_file_new_section (config_file, name, callback_read,
+ callback_write, callback_write_default);
+}
+
+/*
+ * plugin_api_config_new_option: create new option in a config section
+ */
+
+struct t_config_option *
+plugin_api_config_new_option (struct t_weechat_plugin *plugin,
+ void *section, char *name, char *type,
+ char *description, char *string_values,
+ int min, int max, char *default_value,
+ void (*callback_change)())
+
+{
+ long number;
+ char *error;
+
+ /* make C compiler happy */
+ (void) plugin;
+
+ if (string_strcasecmp (type, "boolean") == 0)
+ {
+ return config_file_new_option_boolean (
+ section, name, description,
+ (config_file_string_boolean_value (default_value) == CONFIG_BOOLEAN_TRUE) ?
+ CONFIG_BOOLEAN_TRUE : CONFIG_BOOLEAN_FALSE,
+ callback_change);
+ }
+ if (string_strcasecmp (type, "integer") == 0)
+ {
+ error = NULL;
+ number = strtol (default_value, &error, 10);
+ if (error && (error[0] == '\0'))
+ {
+ if (string_values && string_values[0])
+ return config_file_new_option_integer_with_string (
+ section, name, description, string_values, number,
+ callback_change);
+ return config_file_new_option_integer (
+ section, name, description, min, max, number,
+ callback_change);
+ }
+ else
+ return NULL;
+ }
+ if (string_strcasecmp (type, "string") == 0)
+ {
+ return config_file_new_option_string (
+ section, name, description, min, max, default_value,
+ callback_change);
+ }
+ if (string_strcasecmp (type, "color") == 0)
+ {
+ return config_file_new_option_color (
+ section, name, description, min, default_value,
+ callback_change);
+ }
+
+ /* unknown option type */
+ return NULL;
+}
+
+/*
+ * plugin_api_config_boolean: return boolean value of an option
+ */
+
+char
+plugin_api_config_boolean (struct t_weechat_plugin *plugin, void *option)
+{
+ if (plugin && config_file_option_valid_for_plugin (plugin, option)
+ && (((struct t_config_option *)option)->type == CONFIG_OPTION_BOOLEAN))
+ return CONFIG_BOOLEAN((struct t_config_option *)option);
+ else
+ return 0;
+}
+
+/*
+ * plugin_api_config_integer: return integer value of an option
+ */
+
+int
+plugin_api_config_integer (struct t_weechat_plugin *plugin, void *option)
+{
+ if (plugin && config_file_option_valid_for_plugin (plugin, option)
+ && (((struct t_config_option *)option)->type == CONFIG_OPTION_INTEGER))
+ return CONFIG_INTEGER((struct t_config_option *)option);
+ else
+ return 0;
+}
+
+/*
+ * plugin_api_config_string: return string value of an option
+ */
+
+char *
+plugin_api_config_string (struct t_weechat_plugin *plugin, void *option)
+{
+ if (plugin && config_file_option_valid_for_plugin (plugin, option)
+ && (((struct t_config_option *)option)->type == CONFIG_OPTION_STRING))
+ return CONFIG_STRING((struct t_config_option *)option);
+ else
+ return NULL;
+}
+
+/*
+ * plugin_api_config_color: return color value of an option
+ */
+
+int
+plugin_api_config_color (struct t_weechat_plugin *plugin, void *option)
+{
+ if (plugin && config_file_option_valid_for_plugin (plugin, option)
+ && (((struct t_config_option *)option)->type == CONFIG_OPTION_COLOR))
+ return CONFIG_COLOR((struct t_config_option *)option);
+ else
+ return 0;
+}
+
+/*
+ * plugin_api_get_config_str_value: return string value for any option
+ * This function should never be called directly
+ * (only used by weechat_get_config)
+ */
+
+char *
+plugin_api_get_config_str_value (struct t_config_option *option)
+{
+ char buf_temp[1024], *color_name;
+
+ switch (option->type)
+ {
+ case CONFIG_OPTION_BOOLEAN:
+ return (CONFIG_BOOLEAN(option) == CONFIG_BOOLEAN_TRUE) ?
+ strdup ("on") : strdup ("off");
+ case CONFIG_OPTION_INTEGER:
+ if (option->string_values)
+ snprintf (buf_temp, sizeof (buf_temp), "%s",
+ option->string_values[CONFIG_INTEGER(option)]);
+ else
+ snprintf (buf_temp, sizeof (buf_temp), "%d",
+ CONFIG_INTEGER(option));
+ return strdup (buf_temp);
+ case CONFIG_OPTION_STRING:
+ return strdup (CONFIG_STRING(option));
+ case CONFIG_OPTION_COLOR:
+ color_name = gui_color_get_name (CONFIG_INTEGER(option));
+ return (color_name) ? strdup (color_name) : strdup ("");
+ }
+
+ /* should never be executed! */
+ return NULL;
+}
+
+/*
+ * plugin_api_config_get: get value of a WeeChat config option
+ */
+
+char *
+plugin_api_config_get (struct t_weechat_plugin *plugin, char *option_name)
+{
+ struct t_config_option *ptr_option;
+
+ /* make C compiler happy */
+ (void) plugin;
+
+ /* search WeeChat config option */
+ ptr_option = config_file_search_option (weechat_config, NULL, option_name);
+ if (ptr_option)
+ return plugin_api_get_config_str_value (ptr_option);
+
+ /* option not found */
+ return NULL;
+}
+
+/*
+ * plugin_api_config_set: set value of a config option
+ */
+
+int
+plugin_api_config_set (struct t_weechat_plugin *plugin, char *option_name,
+ char *value)
+{
+ struct t_config_option *ptr_option;
+ int rc;
+
+ /* make C compiler happy */
+ (void) plugin;
+
+ if (!option_name || !value)
+ return 0;
+
+ /* search and set WeeChat config option if found */
+ ptr_option = config_file_search_option (weechat_config, NULL, option_name);
+ if (ptr_option)
+ {
+ rc = config_file_option_set (ptr_option, value);
+ if ((rc == 2) && (ptr_option->callback_change))
+ (void) (ptr_option->callback_change) ();
+ if (rc == 0)
+ return 0;
+ return 1;
+ }
+
+ /* failed to set config option */
+ return 0;
+}
+
+/*
+ * plugin_api_plugin_config_get: get value of a plugin config option
+ */
+
+char *
+plugin_api_plugin_config_get (struct t_weechat_plugin *plugin, char *option_name)
+{
+ struct t_config_option *ptr_option;
+
+ if (!option_name)
+ return NULL;
+
+ ptr_option = plugin_config_search (plugin->name, option_name);
+ if (ptr_option)
+ return (ptr_option->value) ? strdup (ptr_option->value) : NULL;
+
+ /* option not found */
+ return NULL;
+}
+
+/*
+ * plugin_api_plugin_config_set: set value of a plugin config option
+ */
+
+int
+plugin_api_plugin_config_set (struct t_weechat_plugin *plugin,
+ char *option_name, char *value)
+{
+ if (!option_name)
+ return 0;
+
+ if (plugin_config_set (plugin->name, option_name, value))
+ return 1;
+
+ return 0;
+}
+
+/*
* plugin_api_prefix: return a prefix for display with printf
*/
@@ -835,21 +1105,21 @@ plugin_api_list_get_add_buffer (struct t_plugin_list *list,
if (!plugin_list_new_var_pointer (ptr_item, "pointer", buffer))
return 0;
- if (!plugin_list_new_var_int (ptr_item, "number", buffer->number))
+ if (!plugin_list_new_var_integer (ptr_item, "number", buffer->number))
return 0;
if (!plugin_list_new_var_string (ptr_item, "category", buffer->category))
return 0;
if (!plugin_list_new_var_string (ptr_item, "name", buffer->name))
return 0;
- if (!plugin_list_new_var_int (ptr_item, "type", buffer->type))
+ if (!plugin_list_new_var_integer (ptr_item, "type", buffer->type))
return 0;
- if (!plugin_list_new_var_int (ptr_item, "notify_level", buffer->notify_level))
+ if (!plugin_list_new_var_integer (ptr_item, "notify_level", buffer->notify_level))
return 0;
- if (!plugin_list_new_var_int (ptr_item, "num_displayed", buffer->num_displayed))
+ if (!plugin_list_new_var_integer (ptr_item, "num_displayed", buffer->num_displayed))
return 0;
if (!plugin_list_new_var_string (ptr_item, "title", buffer->title))
return 0;
- if (!plugin_list_new_var_int (ptr_item, "input", buffer->input))
+ if (!plugin_list_new_var_integer (ptr_item, "input", buffer->input))
return 0;
if (!plugin_list_new_var_string (ptr_item, "input_nick", buffer->input_nick))
return 0;
@@ -1024,19 +1294,19 @@ plugin_api_list_fields (struct t_weechat_plugin *plugin, void *list)
}
/*
- * plugin_api_list_int: get an integer variable value in current list item
+ * plugin_api_list_integer: get an integer variable value in current list item
*/
int
-plugin_api_list_int (struct t_weechat_plugin *plugin, void *list,
- char *var)
+plugin_api_list_integer (struct t_weechat_plugin *plugin, void *list,
+ char *var)
{
if (!plugin || !list
|| !plugin_list_valid ((struct t_plugin_list *)list)
|| !((struct t_plugin_list *)list)->ptr_item)
return 0;
- return plugin_list_get_int ((struct t_plugin_list *)list, var);
+ return plugin_list_get_integer ((struct t_plugin_list *)list, var);
}
/*
@@ -1099,132 +1369,6 @@ plugin_api_list_free (struct t_weechat_plugin *plugin, void *list)
}
/*
- * plugin_api_get_config_str_value: return string value for any option
- * This function should never be called directly
- * (only used by weechat_get_config)
- */
-
-char *
-plugin_api_get_config_str_value (struct t_config_option *option)
-{
- char buf_temp[1024], *color_name;
-
- switch (option->type)
- {
- case CONFIG_OPTION_BOOLEAN:
- return (CONFIG_BOOLEAN(option) == CONFIG_BOOLEAN_TRUE) ?
- strdup ("on") : strdup ("off");
- case CONFIG_OPTION_INTEGER:
- if (option->string_values)
- snprintf (buf_temp, sizeof (buf_temp), "%s",
- option->string_values[CONFIG_INTEGER(option)]);
- else
- snprintf (buf_temp, sizeof (buf_temp), "%d",
- CONFIG_INTEGER(option));
- return strdup (buf_temp);
- case CONFIG_OPTION_STRING:
- return strdup (CONFIG_STRING(option));
- case CONFIG_OPTION_COLOR:
- color_name = gui_color_get_name (CONFIG_INTEGER(option));
- return (color_name) ? strdup (color_name) : strdup ("");
- }
-
- /* should never be executed! */
- return NULL;
-}
-
-/*
- * plugin_api_config_get: get value of a WeeChat config option
- */
-
-char *
-plugin_api_config_get (struct t_weechat_plugin *plugin, char *option_name)
-{
- struct t_config_option *ptr_option;
-
- /* make C compiler happy */
- (void) plugin;
-
- /* search WeeChat config option */
- ptr_option = config_file_search_option (weechat_config, NULL, option_name);
- if (ptr_option)
- return plugin_api_get_config_str_value (ptr_option);
-
- /* option not found */
- return NULL;
-}
-
-/*
- * plugin_api_config_set: set value of a config option
- */
-
-int
-plugin_api_config_set (struct t_weechat_plugin *plugin, char *option_name,
- char *value)
-{
- struct t_config_option *ptr_option;
- int rc;
-
- /* make C compiler happy */
- (void) plugin;
-
- if (!option_name || !value)
- return 0;
-
- /* search and set WeeChat config option if found */
- ptr_option = config_file_search_option (weechat_config, NULL, option_name);
- if (ptr_option)
- {
- rc = config_file_option_set (ptr_option, value);
- if ((rc == 2) && (ptr_option->callback_change))
- (void) (ptr_option->callback_change) ();
- if (rc == 0)
- return 0;
- return 1;
- }
-
- /* failed to set config option */
- return 0;
-}
-
-/*
- * plugin_api_plugin_config_get: get value of a plugin config option
- */
-
-char *
-plugin_api_plugin_config_get (struct t_weechat_plugin *plugin, char *option_name)
-{
- struct t_config_option *ptr_option;
-
- if (!option_name)
- return NULL;
-
- ptr_option = plugin_config_search (plugin->name, option_name);
- if (ptr_option)
- return (ptr_option->value) ? strdup (ptr_option->value) : NULL;
-
- /* option not found */
- return NULL;
-}
-
-/*
- * plugin_api_plugin_config_set: set value of a plugin config option
- */
-
-int
-plugin_api_plugin_config_set (struct t_weechat_plugin *plugin,
- char *option_name, char *value)
-{
- if (!option_name)
- return 0;
-
- if (plugin_config_set (plugin->name, option_name, value))
- return 1;
-
- return 0;
-}
-
-/*
* plugin_api_log: add a message in buffer log file
*/
@@ -1256,5 +1400,5 @@ plugin_api_log (struct t_weechat_plugin *plugin,
gui_log_write_line (ptr_buffer, (buf2) ? buf2 : buf);
if (buf2)
free (buf2);
- }*/
+ }*/
}
diff --git a/src/plugins/plugin-api.h b/src/plugins/plugin-api.h
index 7dcb54361..2b98ecac3 100644
--- a/src/plugins/plugin-api.h
+++ b/src/plugins/plugin-api.h
@@ -44,6 +44,27 @@ extern int plugin_api_mkdir_home (struct t_weechat_plugin *, char *);
extern void plugin_api_exec_on_files (struct t_weechat_plugin *, char *,
int (*)(char *));
+/* config */
+extern struct t_config_file *config_new (struct t_weechat_plugin *, char *);
+extern struct t_config_section *config_new_section (struct t_weechat_plugin *,
+ void *, char *,
+ void (*)(void *, char *, char *),
+ void (*)(void *),
+ void (*)(void *));
+extern struct t_config_option *config_new_option (struct t_weechat_plugin *,
+ void *, char *, char *,
+ char *, char *, int, int,
+ char *, void (*)());
+extern char config_boolean (struct t_weechat_plugin *, void *);
+extern int config_integer (struct t_weechat_plugin *, void *);
+extern char *config_string (struct t_weechat_plugin *, void *);
+extern int config_color (struct t_weechat_plugin *, void *);
+extern char *plugin_api_config_get (struct t_weechat_plugin *, char *);
+extern int plugin_api_config_set (struct t_weechat_plugin *, char *, char *);
+extern char *plugin_api_plugin_config_get (struct t_weechat_plugin *, char *);
+extern int plugin_api_plugin_config_set (struct t_weechat_plugin *, char *,
+ char *);
+
/* display */
extern char *plugin_api_prefix (struct t_weechat_plugin *, char *);
extern char *plugin_api_color (struct t_weechat_plugin *, char *);
@@ -109,19 +130,12 @@ extern int plugin_api_list_next (struct t_weechat_plugin *,
extern int plugin_api_list_prev (struct t_weechat_plugin *,
void *);
extern char *plugin_api_list_fields (struct t_weechat_plugin *, void *);
-extern int plugin_api_list_int (struct t_weechat_plugin *, void *, char *);
+extern int plugin_api_list_integer (struct t_weechat_plugin *, void *, char *);
extern char *plugin_api_list_string (struct t_weechat_plugin *, void *, char *);
extern void *plugin_api_list_pointer (struct t_weechat_plugin *, void *, char *);
extern time_t plugin_api_list_time (struct t_weechat_plugin *, void *, char *);
extern void plugin_api_list_free (struct t_weechat_plugin *, void *);
-/* config */
-extern char *plugin_api_config_get (struct t_weechat_plugin *, char *);
-extern int plugin_api_config_set (struct t_weechat_plugin *, char *, char *);
-extern char *plugin_api_plugin_config_get (struct t_weechat_plugin *, char *);
-extern int plugin_api_plugin_config_set (struct t_weechat_plugin *, char *,
- char *);
-
/* log */
extern void plugin_api_log (struct t_weechat_plugin *, char *, char *,
char *, ...);
diff --git a/src/plugins/plugin-config.c b/src/plugins/plugin-config.c
index b2976e72a..c0c391e87 100644
--- a/src/plugins/plugin-config.c
+++ b/src/plugins/plugin-config.c
@@ -289,8 +289,7 @@ plugin_config_free_all ()
*/
void
-plugin_config_read_option (struct t_config_file *config_file,
- char *option_name, char *value)
+plugin_config_read_option (void *config_file, char *option_name, char *value)
{
char *value2;
@@ -309,7 +308,7 @@ plugin_config_read_option (struct t_config_file *config_file,
*/
void
-plugin_config_write_options (struct t_config_file *config_file)
+plugin_config_write_options (void *config_file)
{
struct t_config_option *ptr_option;
@@ -329,7 +328,7 @@ plugin_config_write_options (struct t_config_file *config_file)
void
plugin_config_init ()
{
- plugin_config = config_file_new (PLUGIN_CONFIG_FILENAME);
+ plugin_config = config_file_new (NULL, PLUGIN_CONFIG_FILENAME);
if (plugin_config)
{
config_file_new_section (plugin_config, "plugin",
diff --git a/src/plugins/plugin-list.c b/src/plugins/plugin-list.c
index da3de5dac..243041eb8 100644
--- a/src/plugins/plugin-list.c
+++ b/src/plugins/plugin-list.c
@@ -93,12 +93,12 @@ plugin_list_new_item (struct t_plugin_list *list)
}
/*
- * plugin_list_new_var_int: create a new integer variable in an item
+ * plugin_list_new_var_integer: create a new integer variable in an item
*/
struct t_plugin_list_var *
-plugin_list_new_var_int (struct t_plugin_list_item *item,
- char *name, int value)
+plugin_list_new_var_integer (struct t_plugin_list_item *item,
+ char *name, int value)
{
struct t_plugin_list_var *new_var;
@@ -334,11 +334,11 @@ plugin_list_get_fields (struct t_plugin_list *list)
}
/*
- * plugin_list_get_int: get an integer variable value in current list item
+ * plugin_list_get_integer: get an integer variable value in current list item
*/
int
-plugin_list_get_int (struct t_plugin_list *list, char *var)
+plugin_list_get_integer (struct t_plugin_list *list, char *var)
{
struct t_plugin_list_var *ptr_var;
diff --git a/src/plugins/plugin-list.h b/src/plugins/plugin-list.h
index 05ef7204f..b415d4f71 100644
--- a/src/plugins/plugin-list.h
+++ b/src/plugins/plugin-list.h
@@ -67,8 +67,8 @@ extern struct t_plugin_list *last_plugin_list;
extern struct t_plugin_list *plugin_list_new ();
extern struct t_plugin_list_item *plugin_list_new_item (struct t_plugin_list *);
-extern struct t_plugin_list_var *plugin_list_new_var_int (struct t_plugin_list_item *,
- char *, int);
+extern struct t_plugin_list_var *plugin_list_new_var_integer (struct t_plugin_list_item *,
+ char *, int);
extern struct t_plugin_list_var *plugin_list_new_var_string (struct t_plugin_list_item *,
char *, char *);
extern struct t_plugin_list_var *plugin_list_new_var_pointer (struct t_plugin_list_item *,
@@ -79,7 +79,7 @@ extern int plugin_list_valid (struct t_plugin_list *);
extern struct t_plugin_list_item *plugin_list_next_item (struct t_plugin_list *);
extern struct t_plugin_list_item *plugin_list_prev_item (struct t_plugin_list *);
extern char *plugin_list_get_fields (struct t_plugin_list *);
-extern int plugin_list_get_int (struct t_plugin_list *, char *);
+extern int plugin_list_get_integer (struct t_plugin_list *, char *);
extern char *plugin_list_get_string (struct t_plugin_list *, char *);
extern void *plugin_list_get_pointer (struct t_plugin_list *, char *);
extern time_t plugin_list_get_time (struct t_plugin_list *, char *);
diff --git a/src/plugins/plugin.c b/src/plugins/plugin.c
index b8fa1597d..cd5d2cb0a 100644
--- a/src/plugins/plugin.c
+++ b/src/plugins/plugin.c
@@ -269,7 +269,7 @@ plugin_load (char *filename)
new_plugin->list_next = &plugin_api_list_next;
new_plugin->list_prev = &plugin_api_list_prev;
new_plugin->list_fields = &plugin_api_list_fields;
- new_plugin->list_int = &plugin_api_list_int;
+ new_plugin->list_integer = &plugin_api_list_integer;
new_plugin->list_string = &plugin_api_list_string;
new_plugin->list_pointer = &plugin_api_list_pointer;
new_plugin->list_time = &plugin_api_list_time;
diff --git a/src/plugins/weechat-plugin.h b/src/plugins/weechat-plugin.h
index be24519d0..22537e4f5 100644
--- a/src/plugins/weechat-plugin.h
+++ b/src/plugins/weechat-plugin.h
@@ -72,6 +72,27 @@ struct t_weechat_plugin
int (*mkdir_home) (struct t_weechat_plugin *, char *);
void (*exec_on_files) (struct t_weechat_plugin *, char *,
int (*)(char *));
+
+ /* config files */
+ struct t_config_file *(*config_new) (struct t_weechat_plugin *, char *);
+ struct t_config_section *(*config_new_section) (struct t_weechat_plugin *,
+ void *, char *,
+ void (*)(void *, char *, char *),
+ void (*)(void *),
+ void (*)(void *));
+ struct t_config_option *(*config_new_option) (struct t_weechat_plugin *,
+ void *, char *, char *,
+ char *, char *, int, int,
+ char *, void (*)());
+ char (*config_boolean) (struct t_weechat_plugin *, void *);
+ int (*config_integer) (struct t_weechat_plugin *, void *);
+ char *(*config_string) (struct t_weechat_plugin *, void *);
+ int (*config_color) (struct t_weechat_plugin *, void *);
+ char *(*config_get) (struct t_weechat_plugin *, char *);
+ int (*config_set) (struct t_weechat_plugin *, char *, char *);
+ char *(*plugin_config_get) (struct t_weechat_plugin *, char *);
+ int (*plugin_config_set) (struct t_weechat_plugin *, char *, char *);
+
/* display */
char *(*prefix) (struct t_weechat_plugin *, char *);
@@ -128,18 +149,12 @@ struct t_weechat_plugin
int (*list_next) (struct t_weechat_plugin *, void *);
int (*list_prev) (struct t_weechat_plugin *, void *);
char *(*list_fields) (struct t_weechat_plugin *, void *);
- int (*list_int) (struct t_weechat_plugin *, void *, char *);
+ int (*list_integer) (struct t_weechat_plugin *, void *, char *);
char *(*list_string) (struct t_weechat_plugin *, void *, char *);
void *(*list_pointer) (struct t_weechat_plugin *, void *, char *);
time_t (*list_time) (struct t_weechat_plugin *, void *, char *);
void (*list_free) (struct t_weechat_plugin *, void *);
- /* config */
- char *(*config_get) (struct t_weechat_plugin *, char *);
- int (*config_set) (struct t_weechat_plugin *, char *, char *);
- char *(*plugin_config_get) (struct t_weechat_plugin *, char *);
- int (*plugin_config_set) (struct t_weechat_plugin *, char *, char *);
-
/* log */
void (*log) (struct t_weechat_plugin *, char *, char *, char *, ...);
@@ -148,114 +163,158 @@ struct t_weechat_plugin
/* macros for easy call to plugin API */
-#define weechat_charset_set(chset, string) \
- weechat_plugin->charset_set(weechat_plugin, string)
-#define weechat_iconv_to_internal(chset, string) \
- weechat_plugin->iconv_to_internal(weechat_plugin, chset, string)
-#define weechat_iconv_from_internal(chset, string) \
- weechat_plugin->iconv_from_internal(weechat_plugin, chset, string)
+/* strings */
+#define weechat_charset_set(__charset) \
+ weechat_plugin->charset_set(weechat_plugin, __charset)
+#define weechat_iconv_to_internal(__charset, __string) \
+ weechat_plugin->iconv_to_internal(weechat_plugin, \
+ __charset, __string)
+#define weechat_iconv_from_internal(__charset, __string) \
+ weechat_plugin->iconv_from_internal(weechat_plugin, \
+ __charset, __string)
#ifndef __WEECHAT_H
#define _(string) weechat_plugin->gettext(weechat_plugin, string)
#define N_(string) (string)
#define NG_(single,plural,number) \
weechat_plugin->ngettext(weechat_plugin, single, plural, number)
#endif
-#define weechat_strcasecmp(string1, string2) \
- weechat_plugin->strcasecmp(weechat_plugin, string1, string2)
-#define weechat_strncasecmp(string1, string2, max) \
- weechat_plugin->strncasecmp(weechat_plugin, string1, string2, max)
-#define weechat_string_replace(string1, search1, replace1) \
- weechat_plugin->string_replace(weechat_plugin, string1, search1, \
- replace1)
-#define weechat_string_explode(string1, separator, eol, max, \
- num_items) \
- weechat_plugin->string_explode(weechat_plugin, string1, separator, \
- eol, max, num_items)
-#define weechat_string_free_exploded(array_str) \
- weechat_plugin->string_free_exploded(weechat_plugin, array_str)
+#define weechat_strcasecmp(__string1, __string2) \
+ weechat_plugin->strcasecmp(weechat_plugin, __string1, __string2)
+#define weechat_strncasecmp(__string1, __string2, __max) \
+ weechat_plugin->strncasecmp(weechat_plugin, __string1, \
+ __string2, __max)
+#define weechat_string_replace(__string1, __search1, __replace1) \
+ weechat_plugin->string_replace(weechat_plugin, __string1, \
+ __search1, __replace1)
+#define weechat_string_explode(__string1, __separator, __eol, __max, \
+ __num_items) \
+ weechat_plugin->string_explode(weechat_plugin, __string1, \
+ __separator, __eol, __max, \
+ __num_items)
+#define weechat_string_free_exploded(__array_str) \
+ weechat_plugin->string_free_exploded(weechat_plugin, __array_str)
-#define weechat_prefix(prefix_name) \
- weechat_plugin->prefix(weechat_plugin, prefix_name)
-#define weechat_color(color_name) \
- weechat_plugin->color(weechat_plugin, color_name)
-#define weechat_printf(buffer, argz...) \
- weechat_plugin->printf(weechat_plugin, buffer, ##argz)
-#define weechat_printf_date(buffer, datetime, argz...) \
- weechat_plugin->printf_date(weechat_plugin, buffer, datetime, \
- ##argz)
-#define weechat2_log_printf(argz...) \
- weechat_plugin->log_printf(weechat_plugin, ##argz)
+/* directories */
+#define weechat_mkdir_home(__directory) \
+ weechat_plugin->mkdir_home(weechat_plugin, __directory)
+#define weechat_exec_on_files(__directory, __callback) \
+ weechat_plugin->exec_on_files(weechat_plugin, __directory, \
+ __callback)
-#define weechat_hook_command(command, description, args, args_desc, \
- completion, callback, data) \
- weechat_plugin->hook_command(weechat_plugin, command, description, \
- args, args_desc, completion, callback, \
- data)
-#define weechat_hook_timer(interval, max_calls, callback, data) \
- weechat_plugin->hook_timer(weechat_plugin, interval, max_calls, \
- callback, data)
-#define weechat_hook_fd(fd, flag_read, flag_write, flag_exception, \
- callback, data) \
- weechat_plugin->hook_fd(weechat_plugin, fd, flag_read, flag_write, \
- flag_exception, callback, data)
-#define weechat_hook_print(buffer, msg, strip_colors, callback, data) \
- weechat_plugin->hook_print(weechat_plugin, buffer, msg, \
- strip_colors, callback, data)
-#define weechat_hook_event(evnt, callback, data) \
- weechat_plugin->hook_event(weechat_plugin, evnt, callback, data)
-#define weechat_hook_config(type, option, callback, data) \
- weechat_plugin->hook_config(weechat_plugin, type, option, \
- callback, data)
-#define weechat_unhook(hook) \
- weechat_plugin->unhook(weechat_plugin, hook)
+/* config files */
+#define weechat_config_new(__filename) \
+ weechat_plugin->config_new(weechat_plugin, __filename)
+#define weechat_config_new_section(__config, __name, __cb_read, \
+ __cb_write_std, __cb_write_def) \
+ weechat_plugin->config_new_section(weechat_plugin, \
+ __config, __name, __cb_read, \
+ __cb_write_std, __cb_write_def)
+#define weechat_config_new_option(__section, __name, __desc, \
+ __string_values, __min, __max, \
+ __default, __callback) \
+ weechat_plugin->config_new_option(weechat_plugin, \
+ __section, __name, __desc, \
+ __string_values, __min, __max, \
+ __default, __callback)
+#define weechat_config_boolean(__option) \
+ weechat_plugin->config_boolean(weechat_plugin, __option)
+#define weechat_config_integer(__option) \
+ weechat_plugin->config_integer(weechat_plugin, __option)
+#define weechat_config_string(__option) \
+ weechat_plugin->config_string(weechat_plugin, __option)
+#define weechat_config_color(__option) \
+ weechat_plugin->config_color(weechat_plugin, __option)
+#define weechat_config_get(__option) \
+ weechat_plugin->config_get(weechat_plugin, __option)
+#define weechat_config_set(__option, __value) \
+ weechat_plugin->config_set(weechat_plugin, __option, __value)
+#define weechat_plugin_config_get(__option) \
+ weechat_plugin->plugin_config_get(weechat_plugin, __option)
+#define weechat_plugin_config_set(__option, __value) \
+ weechat_plugin->plugin_config_set(weechat_plugin, __option, __value)
+
+/* display */
+#define weechat_prefix(__prefix_name) \
+ weechat_plugin->prefix(weechat_plugin, __prefix_name)
+#define weechat_color(__color_name) \
+ weechat_plugin->color(weechat_plugin, __color_name)
+#define weechat_printf(__buffer, __argz...) \
+ weechat_plugin->printf(weechat_plugin, __buffer, ##__argz)
+#define weechat_printf_date(__buffer, __datetime, __argz...) \
+ weechat_plugin->printf_date(weechat_plugin, __buffer, __datetime, \
+ ##__argz)
+#define weechat2_log_printf(__argz...) \
+ weechat_plugin->log_printf(weechat_plugin, ##__argz)
+
+/* hooks */
+#define weechat_hook_command(__command, __description, __args, \
+ __args_desc, __completion, __callback, \
+ __data) \
+ weechat_plugin->hook_command(weechat_plugin, __command, __description, \
+ __args, __args_desc, __completion, \
+ __callback, __data)
+#define weechat_hook_timer(__interval, __max_calls, __callback, __data) \
+ weechat_plugin->hook_timer(weechat_plugin, __interval, __max_calls, \
+ __callback, __data)
+#define weechat_hook_fd(__fd, __flag_read, __flag_write, \
+ __flag_exception, __callback, __data) \
+ weechat_plugin->hook_fd(weechat_plugin, __fd, __flag_read, \
+ __flag_write, __flag_exception, __callback, \
+ __data)
+#define weechat_hook_print(__buffer, __msg, __stri__colors, __callback, \
+ __data) \
+ weechat_plugin->hook_print(weechat_plugin, __buffer, __msg, \
+ __stri__colors, __callback, __data)
+#define weechat_hook_event(__event, __callback, __data) \
+ weechat_plugin->hook_event(weechat_plugin, __event, __callback, __data)
+#define weechat_hook_config(__type, __option, __callback, __data) \
+ weechat_plugin->hook_config(weechat_plugin, __type, __option, \
+ __callback, __data)
+#define weechat_unhook(__hook) \
+ weechat_plugin->unhook(weechat_plugin, __hook)
#define weechat_unhook_all() \
weechat_plugin->unhook(weechat_plugin)
-#define weechat_buffer_new(category, name, input_data_cb) \
- weechat_plugin->buffer_new(weechat_plugin, category, name, \
- input_data_cb)
-#define weechat_buffer_search(category, name) \
- weechat_plugin->buffer_search(weechat_plugin, category, name)
+/* buffers */
+#define weechat_buffer_new(__category, __name, __input_data_cb) \
+ weechat_plugin->buffer_new(weechat_plugin, __category, __name, \
+ __input_data_cb)
+#define weechat_buffer_search(__category, __name) \
+ weechat_plugin->buffer_search(weechat_plugin, __category, __name)
#define weechat_current_buffer \
weechat_plugin->buffer_search(weechat_plugin, NULL, NULL)
-#define weechat_buffer_close(ptr_buffer) \
- weechat_plugin->buffer_close(weechat_plugin, ptr_buffer)
-#define weechat_buffer_set(ptr_buffer, property, value) \
- weechat_plugin->buffer_set(weechat_plugin, ptr_buffer, \
- property, value)
-
-#define weechat_command(buffer, cmd) \
- weechat_plugin->command(weechat_plugin, buffer, cmd)
+#define weechat_buffer_close(__buffer) \
+ weechat_plugin->buffer_close(weechat_plugin, __buffer)
+#define weechat_buffer_set(__buffer, __property, __value) \
+ weechat_plugin->buffer_set(weechat_plugin, __buffer, \
+ __property, __value)
-#define weechat_info_get(infoname) \
- weechat_plugin->info_get(weechat_plugin, infoname)
+/* command */
+#define weechat_command(__buffer, __command) \
+ weechat_plugin->command(weechat_plugin, __buffer, __command)
-#define weechat_list_get(name, pointer) \
- weechat_plugin->list_get(weechat_plugin, name, pointer)
-#define weechat_list_next(ptrlist) \
- weechat_plugin->list_next(weechat_plugin, ptrlist)
-#define weechat_list_prev(ptrlist) \
- weechat_plugin->list_prev(weechat_plugin, ptrlist)
-#define weechat_list_fields(ptrlist) \
- weechat_plugin->list_fields(weechat_plugin, ptrlist)
-#define weechat_list_int(ptritem, var) \
- weechat_plugin->list_int(weechat_plugin, ptritem, var)
-#define weechat_list_string(ptritem, var) \
- weechat_plugin->list_string(weechat_plugin, ptritem, var)
-#define weechat_list_pointer(ptritem, var) \
- weechat_plugin->list_pointer(weechat_plugin, ptritem, var)
-#define weechat_list_time(ptritem, var) \
- weechat_plugin->list_time(weechat_plugin, ptritem, var)
-#define weechat_list_free(ptrlist) \
- weechat_plugin->list_free(weechat_plugin, ptrlist)
+/* infos */
+#define weechat_info_get(__name) \
+ weechat_plugin->info_get(weechat_plugin, __name)
-#define weechat_config_get(option) \
- weechat_plugin->config_get(weechat_plugin, option)
-#define weechat_config_set(option, value) \
- weechat_plugin->config_set(weechat_plugin, option, value)
-#define weechat_plugin_config_get(option) \
- weechat_plugin->plugin_config_get(weechat_plugin, option)
-#define weechat_plugin_config_set(option, value) \
- weechat_plugin->plugin_config_set(weechat_plugin, option, value)
+/* lists */
+#define weechat_list_get(__name, __pointer) \
+ weechat_plugin->list_get(weechat_plugin, __name, __pointer)
+#define weechat_list_next(__list) \
+ weechat_plugin->list_next(weechat_plugin, __list)
+#define weechat_list_prev(__list) \
+ weechat_plugin->list_prev(weechat_plugin, __list)
+#define weechat_list_fields(__list) \
+ weechat_plugin->list_fields(weechat_plugin, __list)
+#define weechat_list_integer(__item, __var) \
+ weechat_plugin->list_integer(weechat_plugin, __item, __var)
+#define weechat_list_string(__item, __var) \
+ weechat_plugin->list_string(weechat_plugin, __item, __var)
+#define weechat_list_pointer(__item, __var) \
+ weechat_plugin->list_pointer(weechat_plugin, __item, __var)
+#define weechat_list_time(__item, __var) \
+ weechat_plugin->list_time(weechat_plugin, __item, __var)
+#define weechat_list_free(__list) \
+ weechat_plugin->list_free(weechat_plugin, __list)
#endif /* weechat-plugin.h */