summaryrefslogtreecommitdiff
path: root/src/plugins/fset
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/fset')
-rw-r--r--src/plugins/fset/fset-buffer.c43
-rw-r--r--src/plugins/fset/fset-buffer.h4
-rw-r--r--src/plugins/fset/fset-command.c50
-rw-r--r--src/plugins/fset/fset-config.c2
-rw-r--r--src/plugins/fset/fset-info.c8
-rw-r--r--src/plugins/fset/fset-option.c360
-rw-r--r--src/plugins/fset/fset-option.h8
-rw-r--r--src/plugins/fset/fset.c2
8 files changed, 356 insertions, 121 deletions
diff --git a/src/plugins/fset/fset-buffer.c b/src/plugins/fset/fset-buffer.c
index 08d8bf521..b98434dff 100644
--- a/src/plugins/fset/fset-buffer.c
+++ b/src/plugins/fset/fset-buffer.c
@@ -31,12 +31,12 @@
struct t_gui_buffer *fset_buffer = NULL;
-int fset_buffer_selected_line = 0;
+int fset_buffer_selected_line = -1;
struct t_hashtable *fset_buffer_hashtable_pointers = NULL;
struct t_hashtable *fset_buffer_hashtable_extra_vars = NULL;
-char *fset_buffer_columns[] = { "name", "type", "default_value", "value",
- NULL };
-int fset_buffer_columns_default_size[] = { 64, 8, 16, 16 };
+char *fset_buffer_columns[] = { "name", "parent_name", "type", "default_value",
+ "value", NULL };
+int fset_buffer_columns_default_size[] = { 64, 64, 8, 16, 16 };
/*
@@ -44,7 +44,7 @@ int fset_buffer_columns_default_size[] = { 64, 8, 16, 16 };
*/
void
-fset_buffer_display_line (int y, struct t_fset_option *option)
+fset_buffer_display_line (int y, struct t_fset_option *fset_option)
{
char *line, str_format[32], str_value[1024];
const char *ptr_value;
@@ -53,11 +53,12 @@ fset_buffer_display_line (int y, struct t_fset_option *option)
selected_line = (y == fset_buffer_selected_line) ? 1 : 0;
- value_undef = (option->value == NULL) ? 1 : 0;
- value_diff = (fset_option_value_different_from_default (option)) ? 1 : 0;
+ value_undef = (fset_option->value == NULL) ? 1 : 0;
+ value_diff = (fset_option_value_different_from_default (fset_option)) ? 1 : 0;
/* set pointers */
- weechat_hashtable_set (fset_buffer_hashtable_pointers, "fset_option", option);
+ weechat_hashtable_set (fset_buffer_hashtable_pointers,
+ "fset_option", fset_option);
/* set column variables */
for (i = 0; fset_buffer_columns[i]; i++)
@@ -68,7 +69,7 @@ fset_buffer_display_line (int y, struct t_fset_option *option)
"%%-%ds",
(ptr_length) ? *ptr_length : fset_buffer_columns_default_size[i]);
ptr_value = weechat_hdata_string (fset_hdata_fset_option,
- option,
+ fset_option,
fset_buffer_columns[i]);
snprintf (str_value, sizeof (str_value),
str_format,
@@ -109,7 +110,7 @@ fset_buffer_display_line (int y, struct t_fset_option *option)
/* set other variables depending on the value */
weechat_hashtable_set (fset_buffer_hashtable_extra_vars,
"value_undef",
- (option->value == NULL) ? "1" : "0");
+ (fset_option->value == NULL) ? "1" : "0");
/* build string for line */
line = weechat_string_eval_expression (
@@ -134,7 +135,7 @@ fset_buffer_refresh (int clear)
{
char str_title[1024];
int num_options, i;
- struct t_fset_option *ptr_option;
+ struct t_fset_option *ptr_fset_option;
if (!fset_buffer)
return;
@@ -152,8 +153,8 @@ fset_buffer_refresh (int clear)
for (i = 0; i < num_options; i++)
{
- ptr_option = weechat_arraylist_get (fset_options, i);
- fset_buffer_display_line (i, ptr_option);
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
+ fset_buffer_display_line (i, ptr_fset_option);
}
}
@@ -395,14 +396,14 @@ fset_buffer_set_callbacks ()
void
fset_buffer_set_keys ()
{
- char *keys[][2] = { { "meta-t", "toggle" },
- { "meta-+", "increase" },
- { "meta--", "decrease" },
- { "meta-r", "reset" },
- { "meta-u", "unset" },
- { "meta-s", "set" },
- { "meta-a", "append" },
- { NULL, NULL } };
+ char *keys[][2] = { { "meta- ", "toggle" },
+ { "meta--", "decrease" },
+ { "meta-+", "increase" },
+ { "meta-fmeta-r", "reset" },
+ { "meta-fmeta-u", "unset" },
+ { "meta-ctrl-M", "set" },
+ { "meta-a", "append" },
+ { NULL, NULL } };
char str_key[64], str_command[64];
int i;
diff --git a/src/plugins/fset/fset-buffer.h b/src/plugins/fset/fset-buffer.h
index c61ef8061..12fe10ac3 100644
--- a/src/plugins/fset/fset-buffer.h
+++ b/src/plugins/fset/fset-buffer.h
@@ -22,9 +22,13 @@
#define FSET_BUFFER_NAME "fset"
+struct t_fset_option;
+
extern struct t_gui_buffer *fset_buffer;
extern int fset_buffer_selected_line;
+extern void fset_buffer_display_line (int y,
+ struct t_fset_option *fset_option);
extern void fset_buffer_refresh (int clear);
extern void fset_buffer_set_current_line (int line);
extern void fset_buffer_check_line_outside_window ();
diff --git a/src/plugins/fset/fset-command.c b/src/plugins/fset/fset-command.c
index 025f57892..0549b1c46 100644
--- a/src/plugins/fset/fset-command.c
+++ b/src/plugins/fset/fset-command.c
@@ -20,6 +20,7 @@
*/
#include <stdlib.h>
+#include <string.h>
#include "../weechat-plugin.h"
#include "fset.h"
@@ -41,6 +42,8 @@ fset_command_fset (const void *pointer, void *data,
int num_options, line;
long value;
char *error;
+ struct t_fset_option *ptr_fset_option;
+ struct t_config_option *ptr_option;
/* make C compiler happy */
(void) pointer;
@@ -133,6 +136,53 @@ fset_command_fset (const void *pointer, void *data,
return WEECHAT_RC_OK;
}
+ ptr_fset_option = weechat_arraylist_get (fset_options,
+ fset_buffer_selected_line);
+ if (!ptr_fset_option)
+ WEECHAT_COMMAND_ERROR;
+ ptr_option = weechat_config_get (ptr_fset_option->name);
+ if (!ptr_option)
+ WEECHAT_COMMAND_ERROR;
+
+ if (weechat_strcasecmp (argv[1], "-toggle") == 0)
+ {
+ if (strcmp (ptr_fset_option->type, "boolean") == 0)
+ weechat_config_option_set (ptr_option, "toggle", 1);
+ return WEECHAT_RC_OK;
+ }
+
+ if (weechat_strcasecmp (argv[1], "-decrease") == 0)
+ {
+ if ((strcmp (ptr_fset_option->type, "integer") == 0)
+ || (strcmp (ptr_fset_option->type, "color") == 0))
+ {
+ weechat_config_option_set (ptr_option, "--1", 1);
+ }
+ return WEECHAT_RC_OK;
+ }
+
+ if (weechat_strcasecmp (argv[1], "-increase") == 0)
+ {
+ if ((strcmp (ptr_fset_option->type, "integer") == 0)
+ || (strcmp (ptr_fset_option->type, "color") == 0))
+ {
+ weechat_config_option_set (ptr_option, "++1", 1);
+ }
+ return WEECHAT_RC_OK;
+ }
+
+ if (weechat_strcasecmp (argv[1], "-reset") == 0)
+ {
+ weechat_config_option_reset (ptr_option, 1);
+ return WEECHAT_RC_OK;
+ }
+
+ if (weechat_strcasecmp (argv[1], "-unset") == 0)
+ {
+ weechat_config_option_unset (ptr_option);
+ return WEECHAT_RC_OK;
+ }
+
WEECHAT_COMMAND_ERROR;
}
diff --git a/src/plugins/fset/fset-config.c b/src/plugins/fset/fset-config.c
index adc00954d..ced2973ec 100644
--- a/src/plugins/fset/fset-config.c
+++ b/src/plugins/fset/fset-config.c
@@ -179,7 +179,7 @@ fset_config_init ()
N_("format of each line with an option "
"(note: content is evaluated, see /help fset)"),
NULL, 0, 0,
- "${color_name}${name} ${color_type}${type} ${color_value}${value}",
+ " ${color_name}${name} ${color_type}${type} ${color_value}${value}",
NULL, 0,
NULL, NULL, NULL,
&fset_config_change_format, NULL, NULL,
diff --git a/src/plugins/fset/fset-info.c b/src/plugins/fset/fset-info.c
index 193eba6ec..bc6dce156 100644
--- a/src/plugins/fset/fset-info.c
+++ b/src/plugins/fset/fset-info.c
@@ -39,7 +39,7 @@ fset_info_infolist_fset_option_cb (const void *pointer, void *data,
const char *arguments)
{
struct t_infolist *ptr_infolist;
- struct t_fset_option *ptr_option;
+ struct t_fset_option *ptr_fset_option;
int num_options, i;
/* make C compiler happy */
@@ -70,11 +70,11 @@ fset_info_infolist_fset_option_cb (const void *pointer, void *data,
num_options = weechat_arraylist_size (fset_options);
for (i = 0; i < num_options; i++)
{
- ptr_option = weechat_arraylist_get (fset_options, i);
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
if (!arguments || !arguments[0]
- || weechat_string_match (ptr_option->name, arguments, 0))
+ || weechat_string_match (ptr_fset_option->name, arguments, 0))
{
- if (!fset_option_add_to_infolist (ptr_infolist, ptr_option))
+ if (!fset_option_add_to_infolist (ptr_infolist, ptr_fset_option))
{
weechat_infolist_free (ptr_infolist);
return NULL;
diff --git a/src/plugins/fset/fset-option.c b/src/plugins/fset/fset-option.c
index db44b37fb..fb4bda19f 100644
--- a/src/plugins/fset/fset-option.c
+++ b/src/plugins/fset/fset-option.c
@@ -44,47 +44,57 @@ char *fset_option_filter = NULL;
*/
int
-fset_option_valid (struct t_fset_option *option)
+fset_option_valid (struct t_fset_option *fset_option)
{
- struct t_fset_option *ptr_option;
+ struct t_fset_option *ptr_fset_option;
int num_options, i;
- if (!option)
+ if (!fset_option)
return 0;
num_options = weechat_arraylist_size (fset_options);
for (i = 0; i < num_options; i++)
{
- ptr_option = weechat_arraylist_get (fset_options, i);
- if (ptr_option == option)
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
+ if (ptr_fset_option == fset_option)
return 1;
}
- /* option not found */
+ /* fset option not found */
return 0;
}
/*
* Searches for an option by name.
*
+ * If line is not NULL, *line is set with the line number of option found
+ * (-1 if line is not found).
+ *
* Returns pointer to option found, NULL if not found.
*/
struct t_fset_option *
-fset_option_search_by_name (const char *name)
+fset_option_search_by_name (const char *name, int *line)
{
- struct t_fset_option *ptr_option;
+ struct t_fset_option *ptr_fset_option;
int num_options, i;
+ if (line)
+ *line = -1;
+
num_options = weechat_arraylist_size (fset_options);
for (i = 0; i < num_options; i++)
{
- ptr_option = weechat_arraylist_get (fset_options, i);
- if (strcmp (ptr_option->name, name) == 0)
- return ptr_option;
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
+ if (strcmp (ptr_fset_option->name, name) == 0)
+ {
+ if (line)
+ *line = i;
+ return ptr_fset_option;
+ }
}
- /* option not found */
+ /* fset option not found */
return NULL;
}
@@ -97,32 +107,19 @@ fset_option_search_by_name (const char *name)
*/
int
-fset_option_value_different_from_default (struct t_fset_option *option)
+fset_option_value_different_from_default (struct t_fset_option *fset_option)
{
- if (!option->value && !option->default_value)
+ if (!fset_option->value && !fset_option->default_value)
return 0;
- if ((option->value && !option->default_value)
- || (!option->value && option->default_value))
+ if ((fset_option->value && !fset_option->default_value)
+ || (!fset_option->value && fset_option->default_value))
{
return 1;
}
- return (strcmp (option->value, option->default_value) != 0) ? 1 : 0;
-}
-
-/*
- * Sets max length for a field in hashtable "fset_option_max_length_field".
- */
-
-void
-fset_option_set_max_length_field (const char *field, int length)
-{
- int *value;
-
- value = weechat_hashtable_get (fset_option_max_length_field, field);
- if (!value || (length > *value))
- weechat_hashtable_set (fset_option_max_length_field, field, &length);
+ return (strcmp (fset_option->value,
+ fset_option->default_value) != 0) ? 1 : 0;
}
/*
@@ -132,9 +129,11 @@ fset_option_set_max_length_field (const char *field, int length)
void
fset_option_set_value_string (struct t_config_option *option,
const char *type, void *value,
+ int default_value,
char **value_string)
{
char str_value[64];
+ void *ptr_string_values;
int length;
if (!value)
@@ -147,8 +146,18 @@ fset_option_set_value_string (struct t_config_option *option,
}
else if (strcmp (type, "integer") == 0)
{
- snprintf (str_value, sizeof (str_value), "%d", *((int *)value));
- *value_string = strdup (str_value);
+ ptr_string_values = weechat_config_option_get_pointer (
+ option, "string_values");
+ if (ptr_string_values)
+ {
+ *value_string = strdup (
+ (default_value) ? weechat_config_string_default (option) : weechat_config_string (option));
+ }
+ else
+ {
+ snprintf (str_value, sizeof (str_value), "%d", *((int *)value));
+ *value_string = strdup (str_value);
+ }
}
else if (strcmp (type, "string") == 0)
{
@@ -159,7 +168,8 @@ fset_option_set_value_string (struct t_config_option *option,
}
else if (strcmp (type, "color") == 0)
{
- *value_string = strdup (weechat_config_color (option));
+ *value_string = strdup (
+ (default_value) ? weechat_config_color_default (option) : weechat_config_color (option));
}
else
{
@@ -188,6 +198,109 @@ fset_option_match_filters (const char *option_name)
}
/*
+ * Sets (or sets again) values (except name) in an fset option.
+ */
+
+void
+fset_option_set_values (struct t_fset_option *fset_option,
+ struct t_config_option *option)
+{
+ const char *ptr_parent_name, *ptr_type;
+ void *ptr_default_value, *ptr_value;
+
+ /* parent name */
+ if (fset_option->parent_name)
+ free (fset_option->parent_name);
+ ptr_parent_name = weechat_config_option_get_string (option, "parent");
+ fset_option->parent_name = (ptr_parent_name) ? strdup (ptr_parent_name) : NULL;
+
+ /* type */
+ if (fset_option->type)
+ free (fset_option->type);
+ ptr_type = weechat_config_option_get_string (option, "type");
+ fset_option->type = strdup ((ptr_type) ? ptr_type : "");
+
+ /* default value */
+ if (fset_option->default_value)
+ free (fset_option->default_value);
+ ptr_default_value = weechat_config_option_get_pointer (option,
+ "default_value");
+ fset_option_set_value_string (option,
+ fset_option->type,
+ ptr_default_value,
+ 1,
+ &fset_option->default_value);
+
+ /* value */
+ if (fset_option->value)
+ free (fset_option->value);
+ ptr_value = weechat_config_option_get_pointer (option, "value");
+ fset_option_set_value_string (option,
+ fset_option->type,
+ ptr_value,
+ 0,
+ &fset_option->value);
+}
+
+/*
+ * Sets max length for a field in hashtable "fset_option_max_length_field".
+ */
+
+void
+fset_option_set_max_length_field (const char *field, int length)
+{
+ int *value;
+
+ value = weechat_hashtable_get (fset_option_max_length_field, field);
+ if (!value || (length > *value))
+ weechat_hashtable_set (fset_option_max_length_field, field, &length);
+}
+
+/*
+ * Sets max length for fields, for one option.
+ */
+
+void
+fset_option_set_max_length_fields_option (struct t_fset_option *fset_option)
+{
+ fset_option_set_max_length_field ("name", strlen (fset_option->name));
+ fset_option_set_max_length_field (
+ "parent_name",
+ (fset_option->parent_name) ? strlen (fset_option->parent_name) : 0);
+ fset_option_set_max_length_field ("type", strlen (fset_option->type));
+ fset_option_set_max_length_field (
+ "default_value",
+ strlen ((fset_option->default_value) ?
+ fset_option->default_value : "null"));
+ fset_option_set_max_length_field (
+ "value",
+ strlen ((fset_option->value) ?
+ fset_option->value : "null"));
+}
+
+/*
+ * Sets max length for fields, for all options.
+ */
+
+void
+fset_option_set_max_length_fields_all ()
+{
+ int i, num_options;
+ struct t_fset_option *ptr_fset_option;
+
+ /* first clear all max lengths */
+ weechat_hashtable_remove_all (fset_option_max_length_field);
+
+ /* set max length for fields, for all options */
+ num_options = weechat_arraylist_size (fset_options);
+ for (i = 0; i < num_options; i++)
+ {
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
+ fset_option_set_max_length_fields_option (ptr_fset_option);
+ }
+}
+
+/*
* Allocates an fset option structure using a pointer to a
* WeeChat/plugin option.
*
@@ -200,14 +313,12 @@ fset_option_alloc (struct t_config_file *config_file,
struct t_config_section *section,
struct t_config_option *option)
{
- struct t_fset_option *new_option;
+ struct t_fset_option *new_fset_option;
const char *ptr_config_name, *ptr_section_name, *ptr_option_name;
- const char *ptr_type;
- void *ptr_default_value, *ptr_value;
char *option_name;
int length;
- new_option = NULL;
+ new_fset_option = NULL;
option_name = NULL;
ptr_config_name = weechat_hdata_string (fset_hdata_config_file,
@@ -233,42 +344,25 @@ fset_option_alloc (struct t_config_file *config_file,
goto end;
}
- new_option = malloc (sizeof (*new_option));
- if (new_option)
+ new_fset_option = malloc (sizeof (*new_fset_option));
+ if (new_fset_option)
{
- new_option->name = option_name;
- ptr_type = weechat_config_option_get_string (option, "type");
- new_option->type = strdup ((ptr_type) ? ptr_type : "");
- ptr_default_value = weechat_config_option_get_pointer (option,
- "default_value");
- ptr_value = weechat_config_option_get_pointer (option, "value");
- fset_option_set_value_string (option,
- new_option->type,
- ptr_default_value,
- &new_option->default_value);
- fset_option_set_value_string (option,
- new_option->type,
- ptr_value,
- &new_option->value);
- fset_option_set_max_length_field ("name", strlen (new_option->name));
- fset_option_set_max_length_field ("type", strlen (new_option->type));
- fset_option_set_max_length_field (
- "default_value",
- strlen ((new_option->default_value) ?
- new_option->default_value : "null"));
- fset_option_set_max_length_field (
- "value",
- strlen ((new_option->value) ?
- new_option->value : "null"));
+ new_fset_option->name = option_name;
+ new_fset_option->parent_name = NULL;
+ new_fset_option->type = NULL;
+ new_fset_option->default_value = NULL;
+ new_fset_option->value = NULL;
+ fset_option_set_values (new_fset_option, option);
+ fset_option_set_max_length_fields_option (new_fset_option);
}
end:
- if (!new_option)
+ if (!new_fset_option)
{
if (option_name)
free (option_name);
}
- return new_option;
+ return new_fset_option;
}
/*
@@ -336,17 +430,17 @@ int
fset_option_compare_options_cb (void *data, struct t_arraylist *arraylist,
void *pointer1, void *pointer2)
{
- struct t_fset_option *ptr_option1, *ptr_option2;
+ struct t_fset_option *ptr_fset_option1, *ptr_fset_option2;
/* make C compiler happy */
(void) data;
(void) arraylist;
- ptr_option1 = (struct t_fset_option *)pointer1;
- ptr_option2 = (struct t_fset_option *)pointer2;
+ ptr_fset_option1 = (struct t_fset_option *)pointer1;
+ ptr_fset_option2 = (struct t_fset_option *)pointer2;
- return weechat_strcasecmp (ptr_option1->name,
- ptr_option2->name);
+ return weechat_strcasecmp (ptr_fset_option1->name,
+ ptr_fset_option2->name);
}
/*
@@ -356,24 +450,26 @@ fset_option_compare_options_cb (void *data, struct t_arraylist *arraylist,
void
fset_option_free_cb (void *data, struct t_arraylist *arraylist, void *pointer)
{
- struct t_fset_option *option;
+ struct t_fset_option *fset_option;
/* make C compiler happy */
(void) data;
(void) arraylist;
- option = (struct t_fset_option *)pointer;
+ fset_option = (struct t_fset_option *)pointer;
- if (option->name)
- free (option->name);
- if (option->type)
- free (option->type);
- if (option->default_value)
- free (option->default_value);
- if (option->value)
- free (option->value);
+ if (fset_option->name)
+ free (fset_option->name);
+ if (fset_option->parent_name)
+ free (fset_option->parent_name);
+ if (fset_option->type)
+ free (fset_option->type);
+ if (fset_option->default_value)
+ free (fset_option->default_value);
+ if (fset_option->value)
+ free (fset_option->value);
- free (option);
+ free (fset_option);
}
@@ -384,7 +480,7 @@ fset_option_free_cb (void *data, struct t_arraylist *arraylist, void *pointer)
void
fset_option_get_options ()
{
- struct t_fset_option *new_option;
+ struct t_fset_option *new_fset_option;
struct t_config_file *ptr_config;
struct t_config_section *ptr_section;
struct t_config_option *ptr_option;
@@ -404,10 +500,10 @@ fset_option_get_options ()
ptr_section, "options");
while (ptr_option)
{
- new_option = fset_option_alloc (ptr_config, ptr_section,
- ptr_option);
- if (new_option)
- weechat_arraylist_add (fset_options, new_option);
+ new_fset_option = fset_option_alloc (ptr_config, ptr_section,
+ ptr_option);
+ if (new_fset_option)
+ weechat_arraylist_add (fset_options, new_fset_option);
ptr_option = weechat_hdata_move (fset_hdata_config_option,
ptr_option, 1);
}
@@ -445,6 +541,70 @@ fset_option_filter_options (const char *search)
}
/*
+ * Callback for config option changed.
+ */
+
+int
+fset_option_config_cb (const void *pointer,
+ void *data,
+ const char *option,
+ const char *value)
+{
+ const char *ptr_info;
+ struct t_fset_option *ptr_fset_option;
+ struct t_config_option *ptr_option;
+ int line, num_options;
+
+ /* make C compiler happy */
+ (void) pointer;
+ (void) data;
+ (void) value;
+
+ /* do nothing if fset buffer is not opened */
+ if (!fset_buffer)
+ return WEECHAT_RC_OK;
+
+ /* do nothing if WeeChat is upgrading */
+ ptr_info = weechat_info_get ("weechat_upgrading", NULL);
+ if (ptr_info && (strcmp (ptr_info, "1") == 0))
+ return WEECHAT_RC_OK;
+
+ ptr_fset_option = fset_option_search_by_name (option, &line);
+ if (ptr_fset_option)
+ {
+ ptr_option = weechat_config_get (ptr_fset_option->name);
+ if (ptr_option)
+ {
+ fset_option_set_values (ptr_fset_option, ptr_option);
+ fset_buffer_display_line (line, ptr_fset_option);
+ }
+ else
+ {
+ /* option removed, refresh the whole buffer */
+ fset_buffer_refresh (1);
+ }
+ }
+
+ num_options = weechat_arraylist_size (fset_options);
+ for (line = 0; line < num_options; line++)
+ {
+ ptr_fset_option = weechat_arraylist_get (fset_options, line);
+ if (ptr_fset_option->parent_name
+ && (strcmp (ptr_fset_option->parent_name, option) == 0))
+ {
+ ptr_option = weechat_config_get (ptr_fset_option->name);
+ if (ptr_option)
+ {
+ fset_option_set_values (ptr_fset_option, ptr_option);
+ fset_buffer_display_line (line, ptr_fset_option);
+ }
+ }
+ }
+
+ return WEECHAT_RC_OK;
+}
+
+/*
* Returns hdata for option.
*/
@@ -479,18 +639,26 @@ fset_option_hdata_option_cb (const void *pointer, void *data,
int
fset_option_add_to_infolist (struct t_infolist *infolist,
- struct t_fset_option *option)
+ struct t_fset_option *fset_option)
{
struct t_infolist_item *ptr_item;
- if (!infolist || !option)
+ if (!infolist || !fset_option)
return 0;
ptr_item = weechat_infolist_new_item (infolist);
if (!ptr_item)
return 0;
- if (!weechat_infolist_new_var_string (ptr_item, "name", option->name))
+ if (!weechat_infolist_new_var_string (ptr_item, "name", fset_option->name))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "parent_name", fset_option->parent_name))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "type", fset_option->type))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "default_value", fset_option->default_value))
+ return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "value", fset_option->value))
return 0;
return 1;
@@ -503,16 +671,20 @@ fset_option_add_to_infolist (struct t_infolist *infolist,
void
fset_option_print_log ()
{
- struct t_fset_option *ptr_option;
+ struct t_fset_option *ptr_fset_option;
int num_options, i;
num_options = weechat_arraylist_size (fset_options);
for (i = 0; i < num_options; i++)
{
- ptr_option = weechat_arraylist_get (fset_options, i);
+ ptr_fset_option = weechat_arraylist_get (fset_options, i);
weechat_log_printf ("");
- weechat_log_printf ("[fset option (addr:0x%lx)]", ptr_option);
- weechat_log_printf (" name. . . . . . . . . : '%s'", ptr_option->name);
+ weechat_log_printf ("[fset option (addr:0x%lx)]", ptr_fset_option);
+ weechat_log_printf (" name. . . . . . . . . : '%s'", ptr_fset_option->name);
+ weechat_log_printf (" parent_name . . . . . : '%s'", ptr_fset_option->parent_name);
+ weechat_log_printf (" type. . . . . . . . . : '%s'", ptr_fset_option->type);
+ weechat_log_printf (" default_value . . . . : '%s'", ptr_fset_option->default_value);
+ weechat_log_printf (" value . . . . . . . . : '%s'", ptr_fset_option->value);
}
}
diff --git a/src/plugins/fset/fset-option.h b/src/plugins/fset/fset-option.h
index c1382b880..e4381777e 100644
--- a/src/plugins/fset/fset-option.h
+++ b/src/plugins/fset/fset-option.h
@@ -32,6 +32,7 @@
struct t_fset_option
{
char *name; /* option name */
+ char *parent_name; /* parent option name */
char *type; /* option type */
char *default_value; /* option default value */
char *value; /* option value */
@@ -44,11 +45,16 @@ extern struct t_hashtable *fset_option_max_length_field;
extern char *fset_option_filter;
extern int fset_option_valid (struct t_fset_option *option);
-extern struct t_fset_option *fset_option_search_by_name (const char *name);
+extern struct t_fset_option *fset_option_search_by_name (const char *name,
+ int *line);
extern int fset_option_value_different_from_default (struct t_fset_option *option);
extern void fset_option_set_filter (const char *filter);
extern void fset_option_get_options ();
extern void fset_option_filter_options (const char *search);
+extern int fset_option_config_cb (const void *pointer,
+ void *data,
+ const char *option,
+ const char *value);
extern struct t_hdata *fset_option_hdata_option_cb (const void *pointer,
void *data,
const char *hdata_name);
diff --git a/src/plugins/fset/fset.c b/src/plugins/fset/fset.c
index 6f2907c6f..9f9386323 100644
--- a/src/plugins/fset/fset.c
+++ b/src/plugins/fset/fset.c
@@ -107,6 +107,8 @@ weechat_plugin_init (struct t_weechat_plugin *plugin, int argc, char *argv[])
fset_mouse_init ();
+ weechat_hook_config ("*", &fset_option_config_cb, NULL, NULL);
+
return WEECHAT_RC_OK;
}