summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/core/wee-config.c4505
-rw-r--r--src/core/wee-secure-config.c107
-rw-r--r--src/plugins/alias/alias-config.c31
-rw-r--r--src/plugins/buflist/buflist-config.c663
-rw-r--r--src/plugins/exec/exec-config.c134
-rw-r--r--src/plugins/fifo/fifo-config.c67
-rw-r--r--src/plugins/fset/fset-config.c1545
-rw-r--r--src/plugins/irc/irc-config.c1921
-rw-r--r--src/plugins/logger/logger-config.c466
-rw-r--r--src/plugins/plugin-config.c5
-rw-r--r--src/plugins/plugin-script-config.c41
-rw-r--r--src/plugins/relay/relay-config.c811
-rw-r--r--src/plugins/script/script-config.c812
-rw-r--r--src/plugins/spell/spell-config.c290
-rw-r--r--src/plugins/trigger/trigger-config.c229
-rw-r--r--src/plugins/trigger/trigger-config.h3
-rw-r--r--src/plugins/typing/typing-config.c148
-rw-r--r--src/plugins/xfer/xfer-config.c595
18 files changed, 6090 insertions, 6283 deletions
diff --git a/src/core/wee-config.c b/src/core/wee-config.c
index 070194c5a..297bdb2cf 100644
--- a/src/core/wee-config.c
+++ b/src/core/wee-config.c
@@ -77,8 +77,8 @@ struct t_config_section *weechat_config_section_palette = NULL;
struct t_config_section *weechat_config_section_color = NULL;
struct t_config_section *weechat_config_section_completion = NULL;
struct t_config_section *weechat_config_section_history = NULL;
-struct t_config_section *weechat_config_section_network = NULL;
struct t_config_section *weechat_config_section_proxy = NULL;
+struct t_config_section *weechat_config_section_network = NULL;
struct t_config_section *weechat_config_section_plugin = NULL;
struct t_config_section *weechat_config_section_signal = NULL;
struct t_config_section *weechat_config_section_bar = NULL;
@@ -92,244 +92,248 @@ struct t_config_section *weechat_config_section_key[GUI_KEY_NUM_CONTEXTS] = {
/* config, startup section */
-struct t_config_option *config_startup_command_after_plugins;
-struct t_config_option *config_startup_command_before_plugins;
-struct t_config_option *config_startup_display_logo;
-struct t_config_option *config_startup_display_version;
-struct t_config_option *config_startup_sys_rlimit;
+struct t_config_option *config_startup_command_after_plugins = NULL;
+struct t_config_option *config_startup_command_before_plugins = NULL;
+struct t_config_option *config_startup_display_logo = NULL;
+struct t_config_option *config_startup_display_version = NULL;
+struct t_config_option *config_startup_sys_rlimit = NULL;
/* config, look & feel section */
-struct t_config_option *config_look_align_end_of_lines;
-struct t_config_option *config_look_align_multiline_words;
-struct t_config_option *config_look_bar_more_down;
-struct t_config_option *config_look_bar_more_left;
-struct t_config_option *config_look_bar_more_right;
-struct t_config_option *config_look_bar_more_up;
-struct t_config_option *config_look_bare_display_exit_on_input;
-struct t_config_option *config_look_bare_display_time_format;
-struct t_config_option *config_look_buffer_auto_renumber;
-struct t_config_option *config_look_buffer_notify_default;
-struct t_config_option *config_look_buffer_position;
-struct t_config_option *config_look_buffer_search_case_sensitive;
-struct t_config_option *config_look_buffer_search_force_default;
-struct t_config_option *config_look_buffer_search_regex;
-struct t_config_option *config_look_buffer_search_where;
-struct t_config_option *config_look_buffer_time_format;
-struct t_config_option *config_look_buffer_time_same;
-struct t_config_option *config_look_chat_space_right;
-struct t_config_option *config_look_color_basic_force_bold;
-struct t_config_option *config_look_color_inactive_buffer;
-struct t_config_option *config_look_color_inactive_message;
-struct t_config_option *config_look_color_inactive_prefix;
-struct t_config_option *config_look_color_inactive_prefix_buffer;
-struct t_config_option *config_look_color_inactive_time;
-struct t_config_option *config_look_color_inactive_window;
-struct t_config_option *config_look_color_nick_offline;
-struct t_config_option *config_look_color_pairs_auto_reset;
-struct t_config_option *config_look_color_real_white;
-struct t_config_option *config_look_command_chars;
-struct t_config_option *config_look_command_incomplete;
-struct t_config_option *config_look_confirm_quit;
-struct t_config_option *config_look_confirm_upgrade;
-struct t_config_option *config_look_day_change;
-struct t_config_option *config_look_day_change_message_1date;
-struct t_config_option *config_look_day_change_message_2dates;
-struct t_config_option *config_look_eat_newline_glitch;
-struct t_config_option *config_look_emphasized_attributes;
-struct t_config_option *config_look_highlight;
-struct t_config_option *config_look_highlight_disable_regex;
-struct t_config_option *config_look_highlight_regex;
-struct t_config_option *config_look_highlight_tags;
-struct t_config_option *config_look_hotlist_add_conditions;
-struct t_config_option *config_look_hotlist_buffer_separator;
-struct t_config_option *config_look_hotlist_count_max;
-struct t_config_option *config_look_hotlist_count_min_msg;
-struct t_config_option *config_look_hotlist_names_count;
-struct t_config_option *config_look_hotlist_names_length;
-struct t_config_option *config_look_hotlist_names_level;
-struct t_config_option *config_look_hotlist_names_merged_buffers;
-struct t_config_option *config_look_hotlist_prefix;
-struct t_config_option *config_look_hotlist_remove;
-struct t_config_option *config_look_hotlist_short_names;
-struct t_config_option *config_look_hotlist_sort;
-struct t_config_option *config_look_hotlist_suffix;
-struct t_config_option *config_look_hotlist_unique_numbers;
-struct t_config_option *config_look_hotlist_update_on_buffer_switch;
-struct t_config_option *config_look_input_cursor_scroll;
-struct t_config_option *config_look_input_multiline_lead_linebreak;
-struct t_config_option *config_look_input_share;
-struct t_config_option *config_look_input_share_overwrite;
-struct t_config_option *config_look_input_undo_max;
-struct t_config_option *config_look_item_away_message;
-struct t_config_option *config_look_item_buffer_filter;
-struct t_config_option *config_look_item_buffer_zoom;
-struct t_config_option *config_look_item_mouse_status;
-struct t_config_option *config_look_item_time_format;
-struct t_config_option *config_look_jump_current_to_previous_buffer;
-struct t_config_option *config_look_jump_previous_buffer_when_closing;
-struct t_config_option *config_look_jump_smart_back_to_buffer;
-struct t_config_option *config_look_key_bind_safe;
-struct t_config_option *config_look_key_grab_delay;
-struct t_config_option *config_look_mouse;
-struct t_config_option *config_look_mouse_timer_delay;
-struct t_config_option *config_look_nick_color_force;
-struct t_config_option *config_look_nick_color_hash;
-struct t_config_option *config_look_nick_color_hash_salt;
-struct t_config_option *config_look_nick_color_stop_chars;
-struct t_config_option *config_look_nick_prefix;
-struct t_config_option *config_look_nick_suffix;
-struct t_config_option *config_look_paste_bracketed;
-struct t_config_option *config_look_paste_bracketed_timer_delay;
-struct t_config_option *config_look_paste_max_lines;
-struct t_config_option *config_look_prefix[GUI_CHAT_NUM_PREFIXES];
-struct t_config_option *config_look_prefix_align;
-struct t_config_option *config_look_prefix_align_max;
-struct t_config_option *config_look_prefix_align_min;
-struct t_config_option *config_look_prefix_align_more;
-struct t_config_option *config_look_prefix_align_more_after;
-struct t_config_option *config_look_prefix_buffer_align;
-struct t_config_option *config_look_prefix_buffer_align_max;
-struct t_config_option *config_look_prefix_buffer_align_more;
-struct t_config_option *config_look_prefix_buffer_align_more_after;
-struct t_config_option *config_look_prefix_same_nick;
-struct t_config_option *config_look_prefix_same_nick_middle;
-struct t_config_option *config_look_prefix_suffix;
-struct t_config_option *config_look_quote_nick_prefix;
-struct t_config_option *config_look_quote_nick_suffix;
-struct t_config_option *config_look_quote_time_format;
-struct t_config_option *config_look_read_marker;
-struct t_config_option *config_look_read_marker_always_show;
-struct t_config_option *config_look_read_marker_string;
-struct t_config_option *config_look_read_marker_update_on_buffer_switch;
-struct t_config_option *config_look_save_config_on_exit;
-struct t_config_option *config_look_save_config_with_fsync;
-struct t_config_option *config_look_save_layout_on_exit;
-struct t_config_option *config_look_scroll_amount;
-struct t_config_option *config_look_scroll_bottom_after_switch;
-struct t_config_option *config_look_scroll_page_percent;
-struct t_config_option *config_look_search_text_not_found_alert;
-struct t_config_option *config_look_separator_horizontal;
-struct t_config_option *config_look_separator_vertical;
-struct t_config_option *config_look_tab_width;
-struct t_config_option *config_look_time_format;
-struct t_config_option *config_look_window_auto_zoom;
-struct t_config_option *config_look_window_separator_horizontal;
-struct t_config_option *config_look_window_separator_vertical;
-struct t_config_option *config_look_window_title;
-struct t_config_option *config_look_word_chars_highlight;
-struct t_config_option *config_look_word_chars_input;
+struct t_config_option *config_look_align_end_of_lines = NULL;
+struct t_config_option *config_look_align_multiline_words = NULL;
+struct t_config_option *config_look_bar_more_down = NULL;
+struct t_config_option *config_look_bar_more_left = NULL;
+struct t_config_option *config_look_bar_more_right = NULL;
+struct t_config_option *config_look_bar_more_up = NULL;
+struct t_config_option *config_look_bare_display_exit_on_input = NULL;
+struct t_config_option *config_look_bare_display_time_format = NULL;
+struct t_config_option *config_look_buffer_auto_renumber = NULL;
+struct t_config_option *config_look_buffer_notify_default = NULL;
+struct t_config_option *config_look_buffer_position = NULL;
+struct t_config_option *config_look_buffer_search_case_sensitive = NULL;
+struct t_config_option *config_look_buffer_search_force_default = NULL;
+struct t_config_option *config_look_buffer_search_regex = NULL;
+struct t_config_option *config_look_buffer_search_where = NULL;
+struct t_config_option *config_look_buffer_time_format = NULL;
+struct t_config_option *config_look_buffer_time_same = NULL;
+struct t_config_option *config_look_chat_space_right = NULL;
+struct t_config_option *config_look_color_basic_force_bold = NULL;
+struct t_config_option *config_look_color_inactive_buffer = NULL;
+struct t_config_option *config_look_color_inactive_message = NULL;
+struct t_config_option *config_look_color_inactive_prefix = NULL;
+struct t_config_option *config_look_color_inactive_prefix_buffer = NULL;
+struct t_config_option *config_look_color_inactive_time = NULL;
+struct t_config_option *config_look_color_inactive_window = NULL;
+struct t_config_option *config_look_color_nick_offline = NULL;
+struct t_config_option *config_look_color_pairs_auto_reset = NULL;
+struct t_config_option *config_look_color_real_white = NULL;
+struct t_config_option *config_look_command_chars = NULL;
+struct t_config_option *config_look_command_incomplete = NULL;
+struct t_config_option *config_look_confirm_quit = NULL;
+struct t_config_option *config_look_confirm_upgrade = NULL;
+struct t_config_option *config_look_day_change = NULL;
+struct t_config_option *config_look_day_change_message_1date = NULL;
+struct t_config_option *config_look_day_change_message_2dates = NULL;
+struct t_config_option *config_look_eat_newline_glitch = NULL;
+struct t_config_option *config_look_emphasized_attributes = NULL;
+struct t_config_option *config_look_highlight = NULL;
+struct t_config_option *config_look_highlight_disable_regex = NULL;
+struct t_config_option *config_look_highlight_regex = NULL;
+struct t_config_option *config_look_highlight_tags = NULL;
+struct t_config_option *config_look_hotlist_add_conditions = NULL;
+struct t_config_option *config_look_hotlist_buffer_separator = NULL;
+struct t_config_option *config_look_hotlist_count_max = NULL;
+struct t_config_option *config_look_hotlist_count_min_msg = NULL;
+struct t_config_option *config_look_hotlist_names_count = NULL;
+struct t_config_option *config_look_hotlist_names_length = NULL;
+struct t_config_option *config_look_hotlist_names_level = NULL;
+struct t_config_option *config_look_hotlist_names_merged_buffers = NULL;
+struct t_config_option *config_look_hotlist_prefix = NULL;
+struct t_config_option *config_look_hotlist_remove = NULL;
+struct t_config_option *config_look_hotlist_short_names = NULL;
+struct t_config_option *config_look_hotlist_sort = NULL;
+struct t_config_option *config_look_hotlist_suffix = NULL;
+struct t_config_option *config_look_hotlist_unique_numbers = NULL;
+struct t_config_option *config_look_hotlist_update_on_buffer_switch = NULL;
+struct t_config_option *config_look_input_cursor_scroll = NULL;
+struct t_config_option *config_look_input_multiline_lead_linebreak = NULL;
+struct t_config_option *config_look_input_share = NULL;
+struct t_config_option *config_look_input_share_overwrite = NULL;
+struct t_config_option *config_look_input_undo_max = NULL;
+struct t_config_option *config_look_item_away_message = NULL;
+struct t_config_option *config_look_item_buffer_filter = NULL;
+struct t_config_option *config_look_item_buffer_zoom = NULL;
+struct t_config_option *config_look_item_mouse_status = NULL;
+struct t_config_option *config_look_item_time_format = NULL;
+struct t_config_option *config_look_jump_current_to_previous_buffer = NULL;
+struct t_config_option *config_look_jump_previous_buffer_when_closing = NULL;
+struct t_config_option *config_look_jump_smart_back_to_buffer = NULL;
+struct t_config_option *config_look_key_bind_safe = NULL;
+struct t_config_option *config_look_key_grab_delay = NULL;
+struct t_config_option *config_look_mouse = NULL;
+struct t_config_option *config_look_mouse_timer_delay = NULL;
+struct t_config_option *config_look_nick_color_force = NULL;
+struct t_config_option *config_look_nick_color_hash = NULL;
+struct t_config_option *config_look_nick_color_hash_salt = NULL;
+struct t_config_option *config_look_nick_color_stop_chars = NULL;
+struct t_config_option *config_look_nick_prefix = NULL;
+struct t_config_option *config_look_nick_suffix = NULL;
+struct t_config_option *config_look_paste_bracketed = NULL;
+struct t_config_option *config_look_paste_bracketed_timer_delay = NULL;
+struct t_config_option *config_look_paste_max_lines = NULL;
+struct t_config_option *config_look_prefix[GUI_CHAT_NUM_PREFIXES] = {
+ NULL, NULL, NULL, NULL, NULL,
+};
+struct t_config_option *config_look_prefix_align = NULL;
+struct t_config_option *config_look_prefix_align_max = NULL;
+struct t_config_option *config_look_prefix_align_min = NULL;
+struct t_config_option *config_look_prefix_align_more = NULL;
+struct t_config_option *config_look_prefix_align_more_after = NULL;
+struct t_config_option *config_look_prefix_buffer_align = NULL;
+struct t_config_option *config_look_prefix_buffer_align_max = NULL;
+struct t_config_option *config_look_prefix_buffer_align_more = NULL;
+struct t_config_option *config_look_prefix_buffer_align_more_after = NULL;
+struct t_config_option *config_look_prefix_same_nick = NULL;
+struct t_config_option *config_look_prefix_same_nick_middle = NULL;
+struct t_config_option *config_look_prefix_suffix = NULL;
+struct t_config_option *config_look_quote_nick_prefix = NULL;
+struct t_config_option *config_look_quote_nick_suffix = NULL;
+struct t_config_option *config_look_quote_time_format = NULL;
+struct t_config_option *config_look_read_marker = NULL;
+struct t_config_option *config_look_read_marker_always_show = NULL;
+struct t_config_option *config_look_read_marker_string = NULL;
+struct t_config_option *config_look_read_marker_update_on_buffer_switch = NULL;
+struct t_config_option *config_look_save_config_on_exit = NULL;
+struct t_config_option *config_look_save_config_with_fsync = NULL;
+struct t_config_option *config_look_save_layout_on_exit = NULL;
+struct t_config_option *config_look_scroll_amount = NULL;
+struct t_config_option *config_look_scroll_bottom_after_switch = NULL;
+struct t_config_option *config_look_scroll_page_percent = NULL;
+struct t_config_option *config_look_search_text_not_found_alert = NULL;
+struct t_config_option *config_look_separator_horizontal = NULL;
+struct t_config_option *config_look_separator_vertical = NULL;
+struct t_config_option *config_look_tab_width = NULL;
+struct t_config_option *config_look_time_format = NULL;
+struct t_config_option *config_look_window_auto_zoom = NULL;
+struct t_config_option *config_look_window_separator_horizontal = NULL;
+struct t_config_option *config_look_window_separator_vertical = NULL;
+struct t_config_option *config_look_window_title = NULL;
+struct t_config_option *config_look_word_chars_highlight = NULL;
+struct t_config_option *config_look_word_chars_input = NULL;
/* config, colors section */
-struct t_config_option *config_color_bar_more;
-struct t_config_option *config_color_chat;
-struct t_config_option *config_color_chat_bg;
-struct t_config_option *config_color_chat_buffer;
-struct t_config_option *config_color_chat_channel;
-struct t_config_option *config_color_chat_day_change;
-struct t_config_option *config_color_chat_delimiters;
-struct t_config_option *config_color_chat_highlight;
-struct t_config_option *config_color_chat_highlight_bg;
-struct t_config_option *config_color_chat_host;
-struct t_config_option *config_color_chat_inactive_buffer;
-struct t_config_option *config_color_chat_inactive_window;
-struct t_config_option *config_color_chat_nick;
-struct t_config_option *config_color_chat_nick_colors;
-struct t_config_option *config_color_chat_nick_offline;
-struct t_config_option *config_color_chat_nick_offline_highlight;
-struct t_config_option *config_color_chat_nick_offline_highlight_bg;
-struct t_config_option *config_color_chat_nick_other;
-struct t_config_option *config_color_chat_nick_prefix;
-struct t_config_option *config_color_chat_nick_self;
-struct t_config_option *config_color_chat_nick_suffix;
-struct t_config_option *config_color_chat_prefix[GUI_CHAT_NUM_PREFIXES];
-struct t_config_option *config_color_chat_prefix_buffer;
-struct t_config_option *config_color_chat_prefix_buffer_inactive_buffer;
-struct t_config_option *config_color_chat_prefix_more;
-struct t_config_option *config_color_chat_prefix_suffix;
-struct t_config_option *config_color_chat_read_marker;
-struct t_config_option *config_color_chat_read_marker_bg;
-struct t_config_option *config_color_chat_server;
-struct t_config_option *config_color_chat_tags;
-struct t_config_option *config_color_chat_text_found;
-struct t_config_option *config_color_chat_text_found_bg;
-struct t_config_option *config_color_chat_time;
-struct t_config_option *config_color_chat_time_delimiters;
-struct t_config_option *config_color_chat_value;
-struct t_config_option *config_color_chat_value_null;
-struct t_config_option *config_color_emphasized;
-struct t_config_option *config_color_emphasized_bg;
-struct t_config_option *config_color_input_actions;
-struct t_config_option *config_color_input_text_not_found;
-struct t_config_option *config_color_item_away;
-struct t_config_option *config_color_nicklist_away;
-struct t_config_option *config_color_nicklist_group;
-struct t_config_option *config_color_separator;
-struct t_config_option *config_color_status_count_highlight;
-struct t_config_option *config_color_status_count_msg;
-struct t_config_option *config_color_status_count_other;
-struct t_config_option *config_color_status_count_private;
-struct t_config_option *config_color_status_data_highlight;
-struct t_config_option *config_color_status_data_msg;
-struct t_config_option *config_color_status_data_other;
-struct t_config_option *config_color_status_data_private;
-struct t_config_option *config_color_status_filter;
-struct t_config_option *config_color_status_more;
-struct t_config_option *config_color_status_mouse;
-struct t_config_option *config_color_status_name;
-struct t_config_option *config_color_status_name_ssl;
-struct t_config_option *config_color_status_nicklist_count;
-struct t_config_option *config_color_status_number;
-struct t_config_option *config_color_status_time;
+struct t_config_option *config_color_bar_more = NULL;
+struct t_config_option *config_color_chat = NULL;
+struct t_config_option *config_color_chat_bg = NULL;
+struct t_config_option *config_color_chat_buffer = NULL;
+struct t_config_option *config_color_chat_channel = NULL;
+struct t_config_option *config_color_chat_day_change = NULL;
+struct t_config_option *config_color_chat_delimiters = NULL;
+struct t_config_option *config_color_chat_highlight = NULL;
+struct t_config_option *config_color_chat_highlight_bg = NULL;
+struct t_config_option *config_color_chat_host = NULL;
+struct t_config_option *config_color_chat_inactive_buffer = NULL;
+struct t_config_option *config_color_chat_inactive_window = NULL;
+struct t_config_option *config_color_chat_nick = NULL;
+struct t_config_option *config_color_chat_nick_colors = NULL;
+struct t_config_option *config_color_chat_nick_offline = NULL;
+struct t_config_option *config_color_chat_nick_offline_highlight = NULL;
+struct t_config_option *config_color_chat_nick_offline_highlight_bg = NULL;
+struct t_config_option *config_color_chat_nick_other = NULL;
+struct t_config_option *config_color_chat_nick_prefix = NULL;
+struct t_config_option *config_color_chat_nick_self = NULL;
+struct t_config_option *config_color_chat_nick_suffix = NULL;
+struct t_config_option *config_color_chat_prefix[GUI_CHAT_NUM_PREFIXES] = {
+ NULL, NULL, NULL, NULL, NULL,
+};
+struct t_config_option *config_color_chat_prefix_buffer = NULL;
+struct t_config_option *config_color_chat_prefix_buffer_inactive_buffer = NULL;
+struct t_config_option *config_color_chat_prefix_more = NULL;
+struct t_config_option *config_color_chat_prefix_suffix = NULL;
+struct t_config_option *config_color_chat_read_marker = NULL;
+struct t_config_option *config_color_chat_read_marker_bg = NULL;
+struct t_config_option *config_color_chat_server = NULL;
+struct t_config_option *config_color_chat_tags = NULL;
+struct t_config_option *config_color_chat_text_found = NULL;
+struct t_config_option *config_color_chat_text_found_bg = NULL;
+struct t_config_option *config_color_chat_time = NULL;
+struct t_config_option *config_color_chat_time_delimiters = NULL;
+struct t_config_option *config_color_chat_value = NULL;
+struct t_config_option *config_color_chat_value_null = NULL;
+struct t_config_option *config_color_emphasized = NULL;
+struct t_config_option *config_color_emphasized_bg = NULL;
+struct t_config_option *config_color_input_actions = NULL;
+struct t_config_option *config_color_input_text_not_found = NULL;
+struct t_config_option *config_color_item_away = NULL;
+struct t_config_option *config_color_nicklist_away = NULL;
+struct t_config_option *config_color_nicklist_group = NULL;
+struct t_config_option *config_color_separator = NULL;
+struct t_config_option *config_color_status_count_highlight = NULL;
+struct t_config_option *config_color_status_count_msg = NULL;
+struct t_config_option *config_color_status_count_other = NULL;
+struct t_config_option *config_color_status_count_private = NULL;
+struct t_config_option *config_color_status_data_highlight = NULL;
+struct t_config_option *config_color_status_data_msg = NULL;
+struct t_config_option *config_color_status_data_other = NULL;
+struct t_config_option *config_color_status_data_private = NULL;
+struct t_config_option *config_color_status_filter = NULL;
+struct t_config_option *config_color_status_more = NULL;
+struct t_config_option *config_color_status_mouse = NULL;
+struct t_config_option *config_color_status_name = NULL;
+struct t_config_option *config_color_status_name_ssl = NULL;
+struct t_config_option *config_color_status_nicklist_count = NULL;
+struct t_config_option *config_color_status_number = NULL;
+struct t_config_option *config_color_status_time = NULL;
/* config, completion section */
-struct t_config_option *config_completion_base_word_until_cursor;
-struct t_config_option *config_completion_command_inline;
-struct t_config_option *config_completion_default_template;
-struct t_config_option *config_completion_nick_add_space;
-struct t_config_option *config_completion_nick_case_sensitive;
-struct t_config_option *config_completion_nick_completer;
-struct t_config_option *config_completion_nick_first_only;
-struct t_config_option *config_completion_nick_ignore_chars;
-struct t_config_option *config_completion_partial_completion_alert;
-struct t_config_option *config_completion_partial_completion_command;
-struct t_config_option *config_completion_partial_completion_command_arg;
-struct t_config_option *config_completion_partial_completion_count;
-struct t_config_option *config_completion_partial_completion_other;
-struct t_config_option *config_completion_partial_completion_templates;
+struct t_config_option *config_completion_base_word_until_cursor = NULL;
+struct t_config_option *config_completion_command_inline = NULL;
+struct t_config_option *config_completion_default_template = NULL;
+struct t_config_option *config_completion_nick_add_space = NULL;
+struct t_config_option *config_completion_nick_case_sensitive = NULL;
+struct t_config_option *config_completion_nick_completer = NULL;
+struct t_config_option *config_completion_nick_first_only = NULL;
+struct t_config_option *config_completion_nick_ignore_chars = NULL;
+struct t_config_option *config_completion_partial_completion_alert = NULL;
+struct t_config_option *config_completion_partial_completion_command = NULL;
+struct t_config_option *config_completion_partial_completion_command_arg = NULL;
+struct t_config_option *config_completion_partial_completion_count = NULL;
+struct t_config_option *config_completion_partial_completion_other = NULL;
+struct t_config_option *config_completion_partial_completion_templates = NULL;
/* config, history section */
-struct t_config_option *config_history_display_default;
-struct t_config_option *config_history_max_buffer_lines_minutes;
-struct t_config_option *config_history_max_buffer_lines_number;
-struct t_config_option *config_history_max_commands;
-struct t_config_option *config_history_max_visited_buffers;
+struct t_config_option *config_history_display_default = NULL;
+struct t_config_option *config_history_max_buffer_lines_minutes = NULL;
+struct t_config_option *config_history_max_buffer_lines_number = NULL;
+struct t_config_option *config_history_max_commands = NULL;
+struct t_config_option *config_history_max_visited_buffers = NULL;
/* config, network section */
-struct t_config_option *config_network_connection_timeout;
-struct t_config_option *config_network_gnutls_ca_system;
-struct t_config_option *config_network_gnutls_ca_user;
-struct t_config_option *config_network_gnutls_handshake_timeout;
-struct t_config_option *config_network_proxy_curl;
+struct t_config_option *config_network_connection_timeout = NULL;
+struct t_config_option *config_network_gnutls_ca_system = NULL;
+struct t_config_option *config_network_gnutls_ca_user = NULL;
+struct t_config_option *config_network_gnutls_handshake_timeout = NULL;
+struct t_config_option *config_network_proxy_curl = NULL;
/* config, plugin section */
-struct t_config_option *config_plugin_autoload;
-struct t_config_option *config_plugin_extension;
-struct t_config_option *config_plugin_path;
-struct t_config_option *config_plugin_save_config_on_unload;
+struct t_config_option *config_plugin_autoload = NULL;
+struct t_config_option *config_plugin_extension = NULL;
+struct t_config_option *config_plugin_path = NULL;
+struct t_config_option *config_plugin_save_config_on_unload = NULL;
/* config, signal section */
-struct t_config_option *config_signal_sighup;
-struct t_config_option *config_signal_sigquit;
-struct t_config_option *config_signal_sigterm;
-struct t_config_option *config_signal_sigusr1;
-struct t_config_option *config_signal_sigusr2;
+struct t_config_option *config_signal_sighup = NULL;
+struct t_config_option *config_signal_sigquit = NULL;
+struct t_config_option *config_signal_sigterm = NULL;
+struct t_config_option *config_signal_sigusr1 = NULL;
+struct t_config_option *config_signal_sigusr2 = NULL;
/* other */
@@ -2746,8 +2750,13 @@ config_weechat_init_options ()
if (!weechat_config_file)
return 0;
- config_file_set_version (weechat_config_file, WEECHAT_CONFIG_VERSION,
- &config_weechat_update_cb, NULL, NULL);
+ if (!config_file_set_version (weechat_config_file, WEECHAT_CONFIG_VERSION,
+ &config_weechat_update_cb, NULL, NULL))
+ {
+ config_file_free (weechat_config_file);
+ weechat_config_file = NULL;
+ return 0;
+ }
/* debug */
weechat_config_section_debug = config_file_new_section (
@@ -2758,12 +2767,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
&config_weechat_debug_create_option_cb, NULL, NULL,
&config_weechat_debug_delete_option_cb, NULL, NULL);
- if (!weechat_config_section_debug)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* startup */
weechat_config_section_startup = config_file_new_section (
@@ -2774,54 +2777,51 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_startup)
+ if (weechat_config_section_startup)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_startup_command_after_plugins = config_file_new_option (
+ weechat_config_file, weechat_config_section_startup,
+ "command_after_plugins", "string",
+ N_("command executed when WeeChat starts, after loading plugins; "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_startup_command_before_plugins = config_file_new_option (
+ weechat_config_file, weechat_config_section_startup,
+ "command_before_plugins", "string",
+ N_("command executed when WeeChat starts, before loading plugins; "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_startup_display_logo = config_file_new_option (
+ weechat_config_file, weechat_config_section_startup,
+ "display_logo", "boolean",
+ N_("display WeeChat logo at startup"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_startup_display_version = config_file_new_option (
+ weechat_config_file, weechat_config_section_startup,
+ "display_version", "boolean",
+ N_("display WeeChat version at startup"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_startup_sys_rlimit = config_file_new_option (
+ weechat_config_file, weechat_config_section_startup,
+ "sys_rlimit", "string",
+ N_("set resource limits for WeeChat process, format is: "
+ "\"res1:limit1,res2:limit2\"; resource name is the end of "
+ "constant (RLIMIT_XXX) in lower case (see man setrlimit for "
+ "values); limit -1 means \"unlimited\"; example: set unlimited "
+ "size for core file and max 1GB of virtual memory: "
+ "\"core:-1,as:1000000000\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_sys_rlimit, NULL, NULL,
+ NULL, NULL, NULL);
}
- config_startup_command_after_plugins = config_file_new_option (
- weechat_config_file, weechat_config_section_startup,
- "command_after_plugins", "string",
- N_("command executed when WeeChat starts, after loading plugins; "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_startup_command_before_plugins = config_file_new_option (
- weechat_config_file, weechat_config_section_startup,
- "command_before_plugins", "string",
- N_("command executed when WeeChat starts, before loading plugins; "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_startup_display_logo = config_file_new_option (
- weechat_config_file, weechat_config_section_startup,
- "display_logo", "boolean",
- N_("display WeeChat logo at startup"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_startup_display_version = config_file_new_option (
- weechat_config_file, weechat_config_section_startup,
- "display_version", "boolean",
- N_("display WeeChat version at startup"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_startup_sys_rlimit = config_file_new_option (
- weechat_config_file, weechat_config_section_startup,
- "sys_rlimit", "string",
- N_("set resource limits for WeeChat process, format is: "
- "\"res1:limit1,res2:limit2\"; resource name is the end of constant "
- "(RLIMIT_XXX) in lower case (see man setrlimit for values); limit "
- "-1 means \"unlimited\"; example: set unlimited size for core file "
- "and max 1GB of virtual memory: \"core:-1,as:1000000000\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_sys_rlimit, NULL, NULL,
- NULL, NULL, NULL);
-
/* look */
weechat_config_section_look = config_file_new_section (
weechat_config_file, "look",
@@ -2831,1144 +2831,1152 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_look)
+ if (weechat_config_section_look)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_look_align_end_of_lines = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "align_end_of_lines", "integer",
+ N_("alignment for end of lines (all lines after the first): they "
+ "are starting under this data (time, buffer, prefix, suffix, "
+ "message (default))"),
+ "time|buffer|prefix|suffix|message", 0, 0, "message", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_align_multiline_words = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "align_multiline_words", "boolean",
+ N_("alignment for multiline words according to option "
+ "weechat.look.align_end_of_lines; if disabled, the multiline "
+ "words will not be aligned, which can be useful to not break "
+ "long URLs"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_bar_more_down = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bar_more_down", "string",
+ N_("string displayed when bar can be scrolled down "
+ "(for bars with filling different from \"horizontal\")"),
+ NULL, 0, 0, "++", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_bar_more_left = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bar_more_left", "string",
+ N_("string displayed when bar can be scrolled to the left "
+ "(for bars with filling \"horizontal\")"),
+ NULL, 0, 0, "<<", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_bar_more_right = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bar_more_right", "string",
+ N_("string displayed when bar can be scrolled to the right "
+ "(for bars with filling \"horizontal\")"),
+ NULL, 0, 0, ">>", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_bar_more_up = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bar_more_up", "string",
+ N_("string displayed when bar can be scrolled up "
+ "(for bars with filling different from \"horizontal\")"),
+ NULL, 0, 0, "--", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_bare_display_exit_on_input = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bare_display_exit_on_input", "boolean",
+ N_("exit the bare display mode on any changes in input"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_bare_display_time_format = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "bare_display_time_format", "string",
+ N_("time format in bare display mode (see man strftime for "
+ "date/time specifiers)"),
+ NULL, 0, 0, "%H:%M", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_buffer_auto_renumber = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_auto_renumber", "boolean",
+ N_("automatically renumber buffers to have only consecutive "
+ "numbers and start with number 1; if disabled, gaps between "
+ "buffer numbers are allowed and the first buffer can have a "
+ "number greater than 1"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_auto_renumber, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_buffer_notify_default = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_notify_default", "integer",
+ N_("default notify level for buffers (used to tell WeeChat if "
+ "buffer must be displayed in hotlist or not, according to "
+ "importance of message): all=all messages (default), "
+ "message=messages+highlights, highlight=highlights only, "
+ "none=never display in hotlist"),
+ "none|highlight|message|all", 0, 0, "all", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_notify_default, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_buffer_position = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_position", "integer",
+ N_("position of a new buffer: end = after the end of list (number = "
+ "last number + 1) (default), first_gap = at first available "
+ "number in the list (after the end of list if no number is "
+ "available); this option is used only if the buffer has no "
+ "layout number"),
+ "end|first_gap", 0, 0, "end", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_buffer_search_case_sensitive = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_search_case_sensitive", "boolean",
+ N_("default text search in buffer: case sensitive or not"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_buffer_search_force_default = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_search_force_default", "boolean",
+ N_("force default values for text search in buffer (instead of "
+ "using values from last search in buffer)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_buffer_search_regex = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_search_regex", "boolean",
+ N_("default text search in buffer: if enabled, search POSIX "
+ "extended regular expression, otherwise search simple string"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_buffer_search_where = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_search_where", "integer",
+ N_("default text search in buffer: in message, prefix, prefix and "
+ "message"),
+ "prefix|message|prefix_message", 0, 0, "prefix_message",
+ NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_buffer_time_format = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_time_format", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("time format for each line displayed in buffers (see man "
+ "strftime for date/time specifiers) (note: content is evaluated, "
+ "so you can use colors with format \"${color:xxx}\", see /help "
+ "eval); for example time using grayscale (requires support of "
+ "256 colors): \"${color:252}%H${color:245}%M${color:240}%S\""),
+ NULL, 0, 0, "%H:%M:%S", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_time_format, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_buffer_time_same = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "buffer_time_same", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("time displayed for a message with same time as previous message: "
+ "use a space \" \" to hide time, another string to display this "
+ "string instead of time, or an empty string to disable feature "
+ "(display time) (note: content is evaluated, so you can use "
+ "colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_time_same, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_chat_space_right = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "chat_space_right", "boolean",
+ N_("keep a space on the right side of chat area if there is a bar "
+ "displayed on the right (for both text and read marker)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_color_basic_force_bold = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_basic_force_bold", "boolean",
+ N_("force \"bold\" attribute for light colors and \"darkgray\" in "
+ "basic colors (this option is disabled by default: bold is used "
+ "only if terminal has less than 16 colors)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_buffer", "boolean",
+ N_("use a different color for lines in inactive buffer (when line "
+ "is from a merged buffer not selected)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_message = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_message", "boolean",
+ N_("use a different color for inactive message (when window is not "
+ "current window, or if line is from a merged buffer not selected)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_prefix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_prefix", "boolean",
+ N_("use a different color for inactive prefix (when window is not "
+ "current window, or if line is from a merged buffer not selected)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_prefix_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_prefix_buffer", "boolean",
+ N_("use a different color for inactive buffer name in prefix (when "
+ "window is not current window, or if line is from a merged buffer "
+ "not selected)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_time = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_time", "boolean",
+ N_("use a different color for inactive time (when window is not "
+ "current window, or if line is from a merged buffer not "
+ "selected)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_inactive_window = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_inactive_window", "boolean",
+ N_("use a different color for lines in inactive window (when window "
+ "is not current window)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_nick_offline = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_nick_offline", "boolean",
+ N_("use a different color for offline nicks (not in nicklist any "
+ "more)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_color_pairs_auto_reset = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_pairs_auto_reset", "integer",
+ N_("automatically reset table of color pairs when number of "
+ "available pairs is lower or equal to this number (-1 = "
+ "disable automatic reset, and then a manual \"/color reset\" "
+ "is needed when table is full)"),
+ NULL, -1, 256, "5", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_color_real_white = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "color_real_white", "boolean",
+ N_("if set, uses real white color, disabled by default "
+ "for terms with white background (if you never use "
+ "white background, you should turn on this option to "
+ "see real white instead of default term foreground "
+ "color)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_command_chars = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "command_chars", "string",
+ N_("chars used to determine if input string is a command or not: "
+ "input must start with one of these chars; the slash (\"/\") is "
+ "always considered as command prefix (example: \".$\")"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_command_incomplete = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "command_incomplete", "boolean",
+ N_("if set, incomplete and unambiguous commands are allowed, for "
+ "example /he for /help"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_confirm_quit = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "confirm_quit", "boolean",
+ N_("if set, /quit command must be confirmed with extra argument "
+ "\"-yes\" (see /help quit)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_confirm_upgrade = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "confirm_upgrade", "boolean",
+ N_("if set, /upgrade command must be confirmed with extra argument "
+ "\"-yes\" (see /help upgrade)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_day_change = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "day_change", "boolean",
+ N_("display special message when day changes"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_day_change_message_1date = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "day_change_message_1date", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("message displayed when the day has changed, with one date "
+ "displayed (for example at beginning of buffer) (see man "
+ "strftime for date/time specifiers) (note: content is "
+ "evaluated, so you can use colors with format \"${color:xxx}\", "
+ "see /help eval)"),
+ NULL, 0, 0, "-- %a, %d %b %Y --", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_day_change_message_2dates = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "day_change_message_2dates", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("message displayed when the day has changed, with two dates "
+ "displayed (between two messages); the second date specifiers "
+ "must start with two \"%\" because strftime is called two "
+ "times on this string (see man strftime for date/time "
+ "specifiers) (note: content is evaluated, so you can use "
+ "colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, "-- %%a, %%d %%b %%Y (%a, %d %b %Y) --", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_eat_newline_glitch = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "eat_newline_glitch", "boolean",
+ N_("if set, the eat_newline_glitch will be set to 0; this is used "
+ "to not add new line char at end of each line, and then not "
+ "break text when you copy/paste text from WeeChat to another "
+ "application (this option is disabled by default because it "
+ "can cause serious display bugs)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_eat_newline_glitch, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_emphasized_attributes = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "emphasized_attributes", "string",
+ N_("attributes for emphasized text: one or more attribute chars ("
+ "\"%\" for blink, "
+ "\".\" for \"dim\" (half bright), "
+ "\"*\" for bold, "
+ "\"!\" for reverse, "
+ "\"/\" for italic, "
+ "\"_\" for underline); "
+ "if the string is empty, "
+ "the colors weechat.color.emphasized* are used"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_emphasized_attributes, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "highlight", "string",
+ N_("comma separated list of words to highlight; case insensitive "
+ "comparison (use \"(?-i)\" at beginning of words to make them "
+ "case sensitive), words may begin or end with \"*\" for partial "
+ "match; example: \"test,(?-i)*toto*,flash*\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_highlight_disable_regex = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "highlight_disable_regex", "string",
+ N_("POSIX extended regular expression used to prevent any highlight "
+ "from a message: this option has higher priority over other "
+ "highlight options (if the string is found in the message, the "
+ "highlight is disabled and the other options are ignored), "
+ "regular expression is case insensitive (use \"(?-i)\" at "
+ "beginning to make it case sensitive), examples: "
+ "\"<flash.*>\", \"(?-i)<Flash.*>\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_highlight_disable_regex, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_highlight_regex = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "highlight_regex", "string",
+ N_("POSIX extended regular expression used to check if a message "
+ "has highlight or not, at least one match in string must be "
+ "surrounded by delimiters (chars different from: alphanumeric, "
+ "\"-\", \"_\" and \"|\"), regular expression is case insensitive "
+ "(use \"(?-i)\" at beginning to make it case sensitive), "
+ "examples: \"flashcode|flashy\", \"(?-i)FlashCode|flashy\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_highlight_regex, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_highlight_tags = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "highlight_tags", "string",
+ N_("comma separated list of tags to highlight; case insensitive "
+ "comparison; wildcard \"*\" is allowed in each tag; many tags "
+ "can be separated by \"+\" to make a logical \"and\" between "
+ "tags; examples: \"nick_flashcode\" for messages from nick "
+ "\"FlashCode\", \"irc_notice+nick_toto*\" for notices from a "
+ "nick starting with \"toto\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_highlight_tags, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_add_conditions = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_add_conditions", "string",
+ N_("conditions to add a buffer in hotlist (if notify level is OK "
+ "for the buffer); you can use in these conditions: \"window\" "
+ "(current window pointer), \"buffer\" (buffer pointer to add "
+ "in hotlist), \"priority\" (0 = low, 1 = message, 2 = private, "
+ "3 = highlight); by default a buffer is added to hotlist if "
+ "you are away, or if the buffer is not visible on screen (not "
+ "displayed in any window), or if at least one relay client is "
+ "connected via the weechat protocol"),
+ NULL, 0, 0,
+ "${away} "
+ "|| ${buffer.num_displayed} == 0 "
+ "|| ${info:relay_client_count,weechat,connected} > 0",
+ NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_hotlist_buffer_separator = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_buffer_separator", "string",
+ N_("string displayed between buffers in hotlist"),
+ NULL, 0, 0, ", ", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_count_max = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_count_max", "integer",
+ N_("max number of messages count to display in hotlist for a buffer: "
+ "0 = never display messages count, "
+ "other number = display max N messages count (from the highest "
+ "to lowest priority)"),
+ NULL, 0, GUI_HOTLIST_NUM_PRIORITIES, "2", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_count_min_msg = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_count_min_msg", "integer",
+ N_("display messages count if number of messages is greater or "
+ "equal to this value"),
+ NULL, 1, 100, "2", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_names_count = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_names_count", "integer",
+ N_("max number of names in hotlist (0 = no name displayed, only "
+ "buffer numbers)"),
+ NULL, 0, GUI_BUFFERS_MAX, "3", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_names_length = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_names_length", "integer",
+ N_("max length of names in hotlist (0 = no limit)"),
+ NULL, 0, 32, "0", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_names_level = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_names_level", "integer",
+ N_("level for displaying names in hotlist (combination "
+ "of: 1=join/part, 2=message, 4=private, 8=highlight, "
+ "for example: 12=private+highlight)"),
+ NULL, 1, GUI_HOTLIST_MASK_MAX, "12", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_names_merged_buffers = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_names_merged_buffers", "boolean",
+ N_("if set, force display of names in hotlist for merged buffers"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_prefix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_prefix", "string",
+ N_("text displayed at the beginning of the hotlist"),
+ NULL, 0, 0, "H: ", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_remove = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_remove", "integer",
+ N_("remove buffers in hotlist: buffer = remove buffer by buffer, "
+ "merged = remove all visible merged buffers at once"),
+ "buffer|merged",
+ 0, 0, "merged", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_hotlist_short_names = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_short_names", "boolean",
+ N_("if set, uses short names to display buffer names in hotlist "
+ "(start after first \".\" in name)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_sort = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_sort", "integer",
+ N_("sort of hotlist: group_time_*: group by notify level "
+ "(highlights first) then sort by time, group_number_*: group "
+ "by notify level (highlights first) then sort by number, "
+ "number_*: sort by number; asc = ascending sort, desc = "
+ "descending sort"),
+ "group_time_asc|group_time_desc|group_number_asc|"
+ "group_number_desc|number_asc|number_desc",
+ 0, 0, "group_time_asc", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_hotlist_sort, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_suffix", "string",
+ N_("text displayed at the end of the hotlist"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_unique_numbers = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_unique_numbers", "boolean",
+ N_("keep only unique numbers in hotlist (this applies only on "
+ "hotlist items where name is NOT displayed after number)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_hotlist_update_on_buffer_switch = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "hotlist_update_on_buffer_switch", "boolean",
+ N_("update the hotlist when switching buffers"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_input_cursor_scroll = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "input_cursor_scroll", "integer",
+ N_("number of chars displayed after end of input line when "
+ "scrolling to display end of line"),
+ NULL, 0, 100, "20", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_input_multiline_lead_linebreak = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "input_multiline_lead_linebreak", "boolean",
+ N_("start the input text on a new line when the input contains "
+ "multiple lines, so that the start of the lines align"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_input_share = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "input_share", "integer",
+ N_("share commands, text, or both in input for all buffers (there "
+ "is still local history for each buffer)"),
+ "none|commands|text|all",
+ 0, 0, "none", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_input_share_overwrite = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "input_share_overwrite", "boolean",
+ N_("if set and input is shared, always overwrite input in target "
+ "buffer"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_input_undo_max = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "input_undo_max", "integer",
+ N_("max number of \"undo\" for command line, by buffer (0 = undo "
+ "disabled)"),
+ NULL, 0, 65535, "32", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_item_away_message = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "item_away_message", "boolean",
+ N_("display server away message in away bar item"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_item_away, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_item_buffer_filter = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "item_buffer_filter", "string",
+ N_("string used to show that some lines are filtered in current "
+ "buffer (bar item \"buffer_filter\")"),
+ NULL, 0, 0, "*", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_item_buffer_zoom = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "item_buffer_zoom", "string",
+ N_("string used to show zoom on merged buffer "
+ "(bar item \"buffer_zoom\")"),
+ NULL, 0, 0, "!", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_item_mouse_status = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "item_mouse_status", "string",
+ N_("string used to show if mouse is enabled "
+ "(bar item \"mouse_status\")"),
+ NULL, 0, 0, "M", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_item_time_format = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "item_time_format", "string",
+ N_("time format for \"time\" bar item (see man strftime for "
+ "date/time specifiers) (note: content is evaluated, so you can "
+ "use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, "%H:%M", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_item_time_format, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_jump_current_to_previous_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "jump_current_to_previous_buffer", "boolean",
+ N_("jump to previous buffer displayed when jumping to current "
+ "buffer number with /buffer *N (where N is a buffer number), to "
+ "easily switch to another buffer, then come back to current "
+ "buffer"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_jump_previous_buffer_when_closing = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "jump_previous_buffer_when_closing", "boolean",
+ N_("jump to previously visited buffer when closing a buffer (if "
+ "disabled, then jump to buffer number - 1)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_jump_smart_back_to_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "jump_smart_back_to_buffer", "boolean",
+ N_("jump back to initial buffer after reaching end of hotlist"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_key_bind_safe = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "key_bind_safe", "boolean",
+ N_("allow only binding of \"safe\" keys (beginning with a ctrl or "
+ "meta code)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_key_grab_delay = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "key_grab_delay", "integer",
+ N_("default delay (in milliseconds) to grab a key (using default "
+ "key alt-k); this delay can be overridden in the /input command "
+ "(see /help input)"),
+ NULL, 1, 10000, "800", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_mouse = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "mouse", "boolean",
+ N_("enable mouse support"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_mouse, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_mouse_timer_delay = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "mouse_timer_delay", "integer",
+ N_("delay (in milliseconds) to grab a mouse event: WeeChat will "
+ "wait this delay before processing event"),
+ NULL, 1, 10000, "100", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_nick_color_force = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_color_force", "string",
+ N_("force color for some nicks: hash computed with nickname "
+ "to find color will not be used for these nicks (format is: "
+ "\"nick1:color1;nick2:color2\"); look up for nicks is with "
+ "exact case then lower case, so it's possible to use only lower "
+ "case for nicks in this option; color can include background with "
+ "the format \"text,background\", for example \"yellow,red\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_look_nick_color_force, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_nick_color_hash = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_color_hash", "integer",
+ N_("hash algorithm used to find the color for a nick: djb2 = variant "
+ "of djb2 (position of letters matters: anagrams of a nick have "
+ "different color), djb2_32 = variant of djb2 using 32-bit instead "
+ "of 64-bit integer, sum = sum of letters, sum_32 = sum of letters "
+ "using 32-bit instead of 64-bit integer"),
+ "djb2|sum|djb2_32|sum_32", 0, 0, "djb2", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_nick_color_hash_salt = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_color_hash_salt", "string",
+ N_("salt for the hash algorithm used to find nick colors "
+ "(the nickname is appended to this salt and the hash algorithm "
+ "operates on this string); modifying this shuffles nick colors"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_nick_color_stop_chars = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_color_stop_chars", "string",
+ N_("chars used to stop in nick when computing color with letters of "
+ "nick (at least one char outside this list must be in string "
+ "before stopping) (example: nick \"|nick|away\" with \"|\" in "
+ "chars will return color of nick \"|nick\"); this option has an "
+ "impact on option weechat.look.nick_color_force, so the nick "
+ "for the forced color must not contain the chars ignored by "
+ "this option"),
+ NULL, 0, 0, "_|[", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_nick_prefix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_prefix", "string",
+ N_("text to display before nick in prefix of message, example: "
+ "\"<\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_nick_prefix_suffix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_nick_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "nick_suffix", "string",
+ N_("text to display after nick in prefix of message, example: "
+ "\">\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_nick_prefix_suffix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_paste_bracketed = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "paste_bracketed", "boolean",
+ N_("enable terminal \"bracketed paste mode\" (not supported in all "
+ "terminals/multiplexers): in this mode, pasted text is bracketed "
+ "with control sequences so that WeeChat can differentiate pasted "
+ "text from typed-in text (\"ESC[200~\", followed by the pasted "
+ "text, followed by \"ESC[201~\")"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_paste_bracketed, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_paste_bracketed_timer_delay = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "paste_bracketed_timer_delay", "integer",
+ N_("force end of bracketed paste after this delay (in seconds) if "
+ "the control sequence for end of bracketed paste (\"ESC[201~\") "
+ "was not received in time"),
+ NULL, 1, 60, "10", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_paste_max_lines = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "paste_max_lines", "integer",
+ N_("max number of lines for paste without asking user "
+ "(-1 = disable this feature); this option is used only if the "
+ "bar item \"input_paste\" is used in at least one bar (by default "
+ "it is used in \"input\" bar)"),
+ NULL, -1, INT_MAX, "100", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_prefix[GUI_CHAT_PREFIX_ERROR] = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_error", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("prefix for error messages (note: content is evaluated, so you "
+ "can use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, GUI_CHAT_PREFIX_ERROR_DEFAULT, NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix[GUI_CHAT_PREFIX_NETWORK] = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_network", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("prefix for network messages (note: content is evaluated, so you "
+ "can use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, GUI_CHAT_PREFIX_NETWORK_DEFAULT, NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix[GUI_CHAT_PREFIX_ACTION] = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_action", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("prefix for action messages (note: content is evaluated, so you "
+ "can use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, GUI_CHAT_PREFIX_ACTION_DEFAULT, NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix[GUI_CHAT_PREFIX_JOIN] = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_join", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("prefix for join messages (note: content is evaluated, so you "
+ "can use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, GUI_CHAT_PREFIX_JOIN_DEFAULT, NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix[GUI_CHAT_PREFIX_QUIT] = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_quit", "string",
+ /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
+ N_("prefix for quit messages (note: content is evaluated, so you "
+ "can use colors with format \"${color:xxx}\", see /help eval)"),
+ NULL, 0, 0, GUI_CHAT_PREFIX_QUIT_DEFAULT, NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_align = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_align", "integer",
+ N_("prefix alignment (none, left, right (default))"),
+ "none|left|right", 0, 0, "right", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_align_max = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_align_max", "integer",
+ N_("max size for prefix (0 = no max size)"),
+ NULL, 0, 128, "0", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_align_min = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_align_min", "integer",
+ N_("min size for prefix"),
+ NULL, 0, 128, "0", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix_align_min, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_align_more = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_align_more", "string",
+ N_("char to display if prefix is truncated (must be exactly one "
+ "char on screen)"),
+ NULL, 0, 0, "+", NULL, 0,
+ &config_check_prefix_align_more, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_align_more_after = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_align_more_after", "boolean",
+ N_("display the truncature char (by default \"+\") after the text "
+ "(by replacing the space that should be displayed here); if "
+ "disabled, the truncature char replaces last char of text"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_buffer_align = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_buffer_align", "integer",
+ N_("prefix alignment for buffer name, when many buffers are merged "
+ "with same number (none, left, right (default))"),
+ "none|left|right", 0, 0, "right", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_buffer_align_max = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_buffer_align_max", "integer",
+ N_("max size for buffer name, when many buffers are merged with "
+ "same number (0 = no max size)"),
+ NULL, 0, 128, "0", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_buffer_align_more = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_buffer_align_more", "string",
+ N_("char to display if buffer name is truncated (when many buffers "
+ "are merged with same number) (must be exactly one char on "
+ "screen)"),
+ NULL, 0, 0, "+", NULL, 0,
+ &config_check_prefix_buffer_align_more, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_buffer_align_more_after = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_buffer_align_more_after", "boolean",
+ N_("display the truncature char (by default \"+\") after the text "
+ "(by replacing the space that should be displayed here); if "
+ "disabled, the truncature char replaces last char of text"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_same_nick = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_same_nick", "string",
+ N_("prefix displayed for a message with same nick as previous "
+ "but not next message: use a space \" \" to hide prefix, another "
+ "string to display this string instead of prefix, or an empty "
+ "string to disable feature (display prefix)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix_same_nick, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_same_nick_middle = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_same_nick_middle", "string",
+ N_("prefix displayed for a message with same nick as previous "
+ "and next message: use a space \" \" to hide prefix, another "
+ "string to display this string instead of prefix, or an empty "
+ "string to disable feature (display prefix)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_prefix_same_nick_middle, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_prefix_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "prefix_suffix", "string",
+ N_("string displayed after prefix"),
+ NULL, 0, 0, "|", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_quote_nick_prefix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "quote_nick_prefix", "string",
+ N_("text to display before nick when quoting a message (see /help "
+ "cursor)"),
+ NULL, 0, 0, "<", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_quote_nick_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "quote_nick_suffix", "string",
+ N_("text to display after nick when quoting a message (see /help "
+ "cursor)"),
+ NULL, 0, 0, ">", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_quote_time_format = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "quote_time_format", "string",
+ N_("time format when quoting a message (see /help cursor)"),
+ NULL, 0, 0, "%H:%M:%S", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_read_marker = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "read_marker", "integer",
+ N_("use a marker (line or char) on buffers to show first unread "
+ "line"),
+ "none|line|char",
+ 0, 0, "line", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_read_marker, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_read_marker_always_show = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "read_marker_always_show", "boolean",
+ N_("always show read marker, even if it is after last buffer line"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_read_marker_string = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "read_marker_string", "string",
+ N_("string used to draw read marker line (string is repeated until "
+ "end of line)"),
+ NULL, 0, 0, "- ", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_read_marker, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_read_marker_update_on_buffer_switch = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "read_marker_update_on_buffer_switch", "boolean",
+ N_("update the read marker when switching buffers"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_save_config_on_exit = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "save_config_on_exit", "boolean",
+ N_("save configuration file on exit"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_save_config_on_exit, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_save_config_with_fsync = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "save_config_with_fsync", "boolean",
+ N_("use fsync to synchronize the configuration file with the "
+ "storage device (see man fsync); this is slower but should "
+ "prevent any data loss in case of power failure during the "
+ "save of configuration file"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_save_config_on_exit, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_save_layout_on_exit = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "save_layout_on_exit", "integer",
+ N_("save layout on exit (buffers, windows, or both)"),
+ "none|buffers|windows|all", 0, 0, "none", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_save_layout_on_exit, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_scroll_amount = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "scroll_amount", "integer",
+ N_("how many lines to scroll by with scroll_up and "
+ "scroll_down"),
+ NULL, 1, INT_MAX, "3", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffer_content, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_scroll_bottom_after_switch = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "scroll_bottom_after_switch", "boolean",
+ N_("scroll to bottom of window after switch to another buffer (do "
+ "not remember scroll position in windows); the scroll is done "
+ "only for buffers with formatted content (not free content)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_scroll_page_percent = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "scroll_page_percent", "integer",
+ N_("percent of screen to scroll when scrolling one page up or "
+ "down (for example 100 means one page, 50 half-page)"),
+ NULL, 1, 100, "100", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_search_text_not_found_alert = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "search_text_not_found_alert", "boolean",
+ N_("alert user when text sought is not found in buffer"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_separator_horizontal = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "separator_horizontal", "string",
+ N_("char used to draw horizontal separators around bars and windows "
+ "(empty value will draw a real line with ncurses, but may cause "
+ "bugs with URL selection under some terminals); "
+ "width on screen must be exactly one char"),
+ NULL, 0, 0, "-", NULL, 0,
+ &config_check_separator, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_separator_vertical = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "separator_vertical", "string",
+ N_("char used to draw vertical separators around bars and windows "
+ "(empty value will draw a real line with ncurses); "
+ "width on screen must be exactly one char"),
+ NULL, 0, 0, "", NULL, 0,
+ &config_check_separator, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_tab_width = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "tab_width", "integer",
+ N_("number of spaces used to display tabs in messages"),
+ NULL, 1, TAB_MAX_WIDTH, "1", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_tab_width, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_time_format = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "time_format", "string",
+ N_("time format for dates converted to strings and displayed in "
+ "messages (see man strftime for date/time specifiers)"),
+ NULL, 0, 0, "%a, %d %b %Y %T", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_window_auto_zoom = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "window_auto_zoom", "boolean",
+ N_("automatically zoom on current window if the terminal becomes "
+ "too small to display all windows (use alt-z to unzoom windows "
+ "when the terminal is big enough)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_look_window_separator_horizontal = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "window_separator_horizontal", "boolean",
+ N_("display an horizontal separator between windows"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_window_separator_vertical = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "window_separator_vertical", "boolean",
+ N_("display a vertical separator between windows"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_buffers, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_window_title = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "window_title", "string",
+ N_("title for window (terminal for Curses GUI), set on startup; "
+ "an empty string will keep title unchanged "
+ "(note: content is evaluated, see /help eval); example: "
+ "\"WeeChat ${info:version}\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_window_title, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_word_chars_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "word_chars_highlight", "string",
+ N_("comma-separated list of chars (or range of chars) that are "
+ "considered part of words for highlights; "
+ "each item can be a single char, a range of chars (format: a-z), "
+ "a class of wide character (for example \"alnum\", "
+ "see man wctype); a \"!\" before the item makes it negative "
+ "(ie the char is NOT considered part of words); the value \"*\" "
+ "matches any char; unicode chars are allowed with the format "
+ "\\u1234, for example \\u00A0 for unbreakable space "
+ "(see /help print for supported formats)"),
+ NULL, 0, 0, "!\\u00A0,-,_,|,alnum", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_word_chars_highlight, NULL, NULL,
+ NULL, NULL, NULL);
+ config_look_word_chars_input = config_file_new_option (
+ weechat_config_file, weechat_config_section_look,
+ "word_chars_input", "string",
+ N_("comma-separated list of chars (or range of chars) that are "
+ "considered part of words for command line; "
+ "each item can be a single char, a range of chars (format: a-z), "
+ "a class of wide character (for example \"alnum\", "
+ "see man wctype); a \"!\" before the item makes it negative "
+ "(ie the char is NOT considered part of words); the value \"*\" "
+ "matches any char; unicode chars are allowed with the format "
+ "\\u1234, for example \\u00A0 for unbreakable space "
+ "(see /help print for supported formats)"),
+ NULL, 0, 0, "!\\u00A0,-,_,|,alnum", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_word_chars_input, NULL, NULL,
+ NULL, NULL, NULL);
}
- config_look_align_end_of_lines = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "align_end_of_lines", "integer",
- N_("alignment for end of lines (all lines after the first): they "
- "are starting under this data (time, buffer, prefix, suffix, "
- "message (default))"),
- "time|buffer|prefix|suffix|message", 0, 0, "message", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_align_multiline_words = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "align_multiline_words", "boolean",
- N_("alignment for multiline words according to option "
- "weechat.look.align_end_of_lines; if disabled, the multiline words "
- "will not be aligned, which can be useful to not break long URLs"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_bar_more_down = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bar_more_down", "string",
- N_("string displayed when bar can be scrolled down "
- "(for bars with filling different from \"horizontal\")"),
- NULL, 0, 0, "++", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_bar_more_left = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bar_more_left", "string",
- N_("string displayed when bar can be scrolled to the left "
- "(for bars with filling \"horizontal\")"),
- NULL, 0, 0, "<<", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_bar_more_right = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bar_more_right", "string",
- N_("string displayed when bar can be scrolled to the right "
- "(for bars with filling \"horizontal\")"),
- NULL, 0, 0, ">>", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_bar_more_up = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bar_more_up", "string",
- N_("string displayed when bar can be scrolled up "
- "(for bars with filling different from \"horizontal\")"),
- NULL, 0, 0, "--", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_bare_display_exit_on_input = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bare_display_exit_on_input", "boolean",
- N_("exit the bare display mode on any changes in input"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_bare_display_time_format = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "bare_display_time_format", "string",
- N_("time format in bare display mode (see man strftime for date/time "
- "specifiers)"),
- NULL, 0, 0, "%H:%M", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_buffer_auto_renumber = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_auto_renumber", "boolean",
- N_("automatically renumber buffers to have only consecutive numbers "
- "and start with number 1; if disabled, gaps between buffer numbers "
- "are allowed and the first buffer can have a number greater than 1"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_auto_renumber, NULL, NULL,
- NULL, NULL, NULL);
- config_look_buffer_notify_default = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_notify_default", "integer",
- N_("default notify level for buffers (used to tell WeeChat if buffer "
- "must be displayed in hotlist or not, according to importance "
- "of message): all=all messages (default), "
- "message=messages+highlights, highlight=highlights only, "
- "none=never display in hotlist"),
- "none|highlight|message|all", 0, 0, "all", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_notify_default, NULL, NULL,
- NULL, NULL, NULL);
- config_look_buffer_position = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_position", "integer",
- N_("position of a new buffer: end = after the end of list (number = "
- "last number + 1) (default), first_gap = at first available "
- "number in the list (after the end of list if no number is "
- "available); this option is used only if the buffer has no layout "
- "number"),
- "end|first_gap", 0, 0, "end", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_buffer_search_case_sensitive = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_search_case_sensitive", "boolean",
- N_("default text search in buffer: case sensitive or not"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_buffer_search_force_default = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_search_force_default", "boolean",
- N_("force default values for text search in buffer (instead of using "
- "values from last search in buffer)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_buffer_search_regex = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_search_regex", "boolean",
- N_("default text search in buffer: if enabled, search POSIX extended "
- "regular expression, otherwise search simple string"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_buffer_search_where = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_search_where", "integer",
- N_("default text search in buffer: in message, prefix, prefix and "
- "message"),
- "prefix|message|prefix_message", 0, 0, "prefix_message",
- NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_buffer_time_format = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_time_format", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("time format for each line displayed in buffers (see man strftime "
- "for date/time specifiers) (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval); for "
- "example time using grayscale (requires support of 256 colors): "
- "\"${color:252}%H${color:245}%M${color:240}%S\""),
- NULL, 0, 0, "%H:%M:%S", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_time_format, NULL, NULL,
- NULL, NULL, NULL);
- config_look_buffer_time_same = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "buffer_time_same", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("time displayed for a message with same time as previous message: "
- "use a space \" \" to hide time, another string to display this "
- "string instead of time, or an empty string to disable feature "
- "(display time) (note: content is evaluated, so you can use "
- "colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_time_same, NULL, NULL,
- NULL, NULL, NULL);
- config_look_chat_space_right = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "chat_space_right", "boolean",
- N_("keep a space on the right side of chat area if there is a bar "
- "displayed on the right (for both text and read marker)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_color_basic_force_bold = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_basic_force_bold", "boolean",
- N_("force \"bold\" attribute for light colors and \"darkgray\" in "
- "basic colors (this option is disabled by default: bold is used "
- "only if terminal has less than 16 colors)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_buffer", "boolean",
- N_("use a different color for lines in inactive buffer (when line is "
- "from a merged buffer not selected)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_message = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_message", "boolean",
- N_("use a different color for inactive message (when window is not "
- "current window, or if line is from a merged buffer not selected)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_prefix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_prefix", "boolean",
- N_("use a different color for inactive prefix (when window is not "
- "current window, or if line is from a merged buffer not selected)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_prefix_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_prefix_buffer", "boolean",
- N_("use a different color for inactive buffer name in prefix (when "
- "window is not current window, or if line is from a merged buffer "
- "not selected)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_time = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_time", "boolean",
- N_("use a different color for inactive time (when window is not "
- "current window, or if line is from a merged buffer not selected)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_inactive_window = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_inactive_window", "boolean",
- N_("use a different color for lines in inactive window (when window "
- "is not current window)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_nick_offline = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_nick_offline", "boolean",
- N_("use a different color for offline nicks (not in nicklist any more)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_color_pairs_auto_reset = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_pairs_auto_reset", "integer",
- N_("automatically reset table of color pairs when number of available "
- "pairs is lower or equal to this number (-1 = disable automatic "
- "reset, and then a manual \"/color reset\" is needed when table "
- "is full)"),
- NULL, -1, 256, "5", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_color_real_white = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "color_real_white", "boolean",
- N_("if set, uses real white color, disabled by default "
- "for terms with white background (if you never use "
- "white background, you should turn on this option to "
- "see real white instead of default term foreground "
- "color)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_look_command_chars = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "command_chars", "string",
- N_("chars used to determine if input string is a command or not: "
- "input must start with one of these chars; the slash (\"/\") is "
- "always considered as command prefix (example: \".$\")"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_command_incomplete = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "command_incomplete", "boolean",
- N_("if set, incomplete and unambiguous commands are allowed, for "
- "example /he for /help"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_confirm_quit = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "confirm_quit", "boolean",
- N_("if set, /quit command must be confirmed with extra argument "
- "\"-yes\" (see /help quit)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_confirm_upgrade = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "confirm_upgrade", "boolean",
- N_("if set, /upgrade command must be confirmed with extra argument "
- "\"-yes\" (see /help upgrade)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_day_change = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "day_change", "boolean",
- N_("display special message when day changes"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_day_change_message_1date = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "day_change_message_1date", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("message displayed when the day has changed, with one date displayed "
- "(for example at beginning of buffer) (see man strftime for "
- "date/time specifiers) (note: content is evaluated, so you can use "
- "colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, "-- %a, %d %b %Y --", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_day_change_message_2dates = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "day_change_message_2dates", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("message displayed when the day has changed, with two dates displayed "
- "(between two messages); the second date specifiers must start with "
- "two \"%\" because strftime is called two times on this string "
- "(see man strftime for date/time specifiers) (note: content is "
- "evaluated, so you can use colors with format \"${color:xxx}\", "
- "see /help eval)"),
- NULL, 0, 0, "-- %%a, %%d %%b %%Y (%a, %d %b %Y) --", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_eat_newline_glitch = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "eat_newline_glitch", "boolean",
- N_("if set, the eat_newline_glitch will be set to 0; this is used to "
- "not add new line char at end of each line, and then not break "
- "text when you copy/paste text from WeeChat to another application "
- "(this option is disabled by default because it can cause serious "
- "display bugs)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_eat_newline_glitch, NULL, NULL,
- NULL, NULL, NULL);
- config_look_emphasized_attributes = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "emphasized_attributes", "string",
- N_("attributes for emphasized text: one or more attribute chars ("
- "\"%\" for blink, "
- "\".\" for \"dim\" (half bright), "
- "\"*\" for bold, "
- "\"!\" for reverse, "
- "\"/\" for italic, "
- "\"_\" for underline); "
- "if the string is empty, "
- "the colors weechat.color.emphasized* are used"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_emphasized_attributes, NULL, NULL,
- NULL, NULL, NULL);
- config_look_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "highlight", "string",
- N_("comma separated list of words to highlight; case insensitive "
- "comparison (use \"(?-i)\" at beginning of words to make them case "
- "sensitive), words may begin or end with \"*\" for partial match; "
- "example: \"test,(?-i)*toto*,flash*\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_highlight_disable_regex = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "highlight_disable_regex", "string",
- N_("POSIX extended regular expression used to prevent any highlight "
- "from a message: this option has higher priority over other "
- "highlight options (if the string is found in the message, the "
- "highlight is disabled and the other options are ignored), "
- "regular expression is case insensitive (use \"(?-i)\" at beginning "
- "to make it case sensitive), examples: "
- "\"<flash.*>\", \"(?-i)<Flash.*>\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_highlight_disable_regex, NULL, NULL,
- NULL, NULL, NULL);
- config_look_highlight_regex = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "highlight_regex", "string",
- N_("POSIX extended regular expression used to check if a message has "
- "highlight or not, at least one match in string must be surrounded "
- "by delimiters (chars different from: alphanumeric, \"-\", \"_\" "
- "and \"|\"), regular expression is case insensitive (use \"(?-i)\" "
- "at beginning to make it case sensitive), examples: "
- "\"flashcode|flashy\", \"(?-i)FlashCode|flashy\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_highlight_regex, NULL, NULL,
- NULL, NULL, NULL);
- config_look_highlight_tags = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "highlight_tags", "string",
- N_("comma separated list of tags to highlight; case insensitive "
- "comparison; wildcard \"*\" is allowed in each tag; many tags can "
- "be separated by \"+\" to make a logical \"and\" between tags; "
- "examples: \"nick_flashcode\" for messages from nick \"FlashCode\", "
- "\"irc_notice+nick_toto*\" for notices from a nick starting with "
- "\"toto\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_highlight_tags, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_add_conditions = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_add_conditions", "string",
- N_("conditions to add a buffer in hotlist (if notify level is OK for "
- "the buffer); you can use in these conditions: \"window\" (current "
- "window pointer), \"buffer\" (buffer pointer to add in hotlist), "
- "\"priority\" (0 = low, 1 = message, 2 = private, 3 = highlight); "
- "by default a buffer is added to hotlist if you are away, or "
- "if the buffer is not visible on screen (not displayed in any "
- "window), or if at least one relay client is connected via the "
- "weechat protocol"),
- NULL, 0, 0,
- "${away} "
- "|| ${buffer.num_displayed} == 0 "
- "|| ${info:relay_client_count,weechat,connected} > 0",
- NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_hotlist_buffer_separator = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_buffer_separator", "string",
- N_("string displayed between buffers in hotlist"),
- NULL, 0, 0, ", ", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_count_max = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_count_max", "integer",
- N_("max number of messages count to display in hotlist for a buffer: "
- "0 = never display messages count, "
- "other number = display max N messages count (from the highest to "
- "lowest priority)"),
- NULL, 0, GUI_HOTLIST_NUM_PRIORITIES, "2", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_count_min_msg = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_count_min_msg", "integer",
- N_("display messages count if number of messages is greater or equal "
- "to this value"),
- NULL, 1, 100, "2", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_names_count = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_names_count", "integer",
- N_("max number of names in hotlist (0 = no name displayed, only buffer "
- "numbers)"),
- NULL, 0, GUI_BUFFERS_MAX, "3", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_names_length = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_names_length", "integer",
- N_("max length of names in hotlist (0 = no limit)"),
- NULL, 0, 32, "0", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_names_level = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_names_level", "integer",
- N_("level for displaying names in hotlist (combination "
- "of: 1=join/part, 2=message, 4=private, 8=highlight, "
- "for example: 12=private+highlight)"),
- NULL, 1, GUI_HOTLIST_MASK_MAX, "12", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_names_merged_buffers = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_names_merged_buffers", "boolean",
- N_("if set, force display of names in hotlist for merged buffers"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_prefix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_prefix", "string",
- N_("text displayed at the beginning of the hotlist"),
- NULL, 0, 0, "H: ", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_remove = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_remove", "integer",
- N_("remove buffers in hotlist: buffer = remove buffer by buffer, "
- "merged = remove all visible merged buffers at once"),
- "buffer|merged",
- 0, 0, "merged", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_hotlist_short_names = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_short_names", "boolean",
- N_("if set, uses short names to display buffer names in hotlist (start "
- "after first \".\" in name)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_sort = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_sort", "integer",
- N_("sort of hotlist: group_time_*: group by notify level (highlights "
- "first) then sort by time, group_number_*: group by notify level "
- "(highlights first) then sort by number, number_*: sort by number; "
- "asc = ascending sort, desc = descending sort"),
- "group_time_asc|group_time_desc|group_number_asc|"
- "group_number_desc|number_asc|number_desc",
- 0, 0, "group_time_asc", NULL, 0,
- NULL, NULL, NULL,
- &config_change_hotlist_sort, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_suffix", "string",
- N_("text displayed at the end of the hotlist"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_unique_numbers = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_unique_numbers", "boolean",
- N_("keep only unique numbers in hotlist (this applies only on hotlist "
- "items where name is NOT displayed after number)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_hotlist_update_on_buffer_switch = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "hotlist_update_on_buffer_switch", "boolean",
- N_("update the hotlist when switching buffers"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_input_cursor_scroll = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "input_cursor_scroll", "integer",
- N_("number of chars displayed after end of input line when scrolling "
- "to display end of line"),
- NULL, 0, 100, "20", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_input_multiline_lead_linebreak = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "input_multiline_lead_linebreak", "boolean",
- N_("start the input text on a new line when the input contains "
- "multiple lines, so that the start of the lines align"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_input_share = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "input_share", "integer",
- N_("share commands, text, or both in input for all buffers (there is "
- "still local history for each buffer)"),
- "none|commands|text|all",
- 0, 0, "none", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_input_share_overwrite = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "input_share_overwrite", "boolean",
- N_("if set and input is shared, always overwrite input in target "
- "buffer"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_input_undo_max = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "input_undo_max", "integer",
- N_("max number of \"undo\" for command line, by buffer (0 = undo "
- "disabled)"),
- NULL, 0, 65535, "32", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_item_away_message = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "item_away_message", "boolean",
- N_("display server away message in away bar item"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_item_away, NULL, NULL,
- NULL, NULL, NULL);
- config_look_item_buffer_filter = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "item_buffer_filter", "string",
- N_("string used to show that some lines are filtered in current buffer "
- "(bar item \"buffer_filter\")"),
- NULL, 0, 0, "*", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_item_buffer_zoom = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "item_buffer_zoom", "string",
- N_("string used to show zoom on merged buffer "
- "(bar item \"buffer_zoom\")"),
- NULL, 0, 0, "!", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_item_mouse_status = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "item_mouse_status", "string",
- N_("string used to show if mouse is enabled "
- "(bar item \"mouse_status\")"),
- NULL, 0, 0, "M", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_item_time_format = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "item_time_format", "string",
- N_("time format for \"time\" bar item (see man strftime for date/time "
- "specifiers) (note: content is evaluated, so you can use colors "
- "with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, "%H:%M", NULL, 0,
- NULL, NULL, NULL,
- &config_change_item_time_format, NULL, NULL,
- NULL, NULL, NULL);
- config_look_jump_current_to_previous_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "jump_current_to_previous_buffer", "boolean",
- N_("jump to previous buffer displayed when jumping to current buffer "
- "number with /buffer *N (where N is a buffer number), to easily "
- "switch to another buffer, then come back to current buffer"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_jump_previous_buffer_when_closing = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "jump_previous_buffer_when_closing", "boolean",
- N_("jump to previously visited buffer when closing a buffer (if "
- "disabled, then jump to buffer number - 1)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_jump_smart_back_to_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "jump_smart_back_to_buffer", "boolean",
- N_("jump back to initial buffer after reaching end of hotlist"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_key_bind_safe = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "key_bind_safe", "boolean",
- N_("allow only binding of \"safe\" keys (beginning with a ctrl or meta "
- "code)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_key_grab_delay = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "key_grab_delay", "integer",
- N_("default delay (in milliseconds) to grab a key (using default key "
- "alt-k); this delay can be overridden in the /input command (see "
- "/help input)"),
- NULL, 1, 10000, "800", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_mouse = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "mouse", "boolean",
- N_("enable mouse support"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_mouse, NULL, NULL,
- NULL, NULL, NULL);
- config_look_mouse_timer_delay = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "mouse_timer_delay", "integer",
- N_("delay (in milliseconds) to grab a mouse event: WeeChat will "
- "wait this delay before processing event"),
- NULL, 1, 10000, "100", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_nick_color_force = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_color_force", "string",
- N_("force color for some nicks: hash computed with nickname "
- "to find color will not be used for these nicks (format is: "
- "\"nick1:color1;nick2:color2\"); look up for nicks is with "
- "exact case then lower case, so it's possible to use only lower "
- "case for nicks in this option; color can include background with "
- "the format \"text,background\", for example \"yellow,red\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_look_nick_color_force, NULL, NULL,
- NULL, NULL, NULL);
- config_look_nick_color_hash = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_color_hash", "integer",
- N_("hash algorithm used to find the color for a nick: djb2 = variant "
- "of djb2 (position of letters matters: anagrams of a nick have "
- "different color), djb2_32 = variant of djb2 using 32-bit instead "
- "of 64-bit integer, sum = sum of letters, sum_32 = sum of letters "
- "using 32-bit instead of 64-bit integer"),
- "djb2|sum|djb2_32|sum_32", 0, 0, "djb2", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_nick_color_hash_salt = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_color_hash_salt", "string",
- N_("salt for the hash algorithm used to find nick colors "
- "(the nickname is appended to this salt and the hash algorithm "
- "operates on this string); modifying this shuffles nick colors"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_nick_color_stop_chars = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_color_stop_chars", "string",
- N_("chars used to stop in nick when computing color with letters of "
- "nick (at least one char outside this list must be in string before "
- "stopping) (example: nick \"|nick|away\" with \"|\" in chars will "
- "return color of nick \"|nick\"); this option has an impact on "
- "option weechat.look.nick_color_force, so the nick for the forced "
- "color must not contain the chars ignored by this option"),
- NULL, 0, 0, "_|[", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- config_look_nick_prefix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_prefix", "string",
- N_("text to display before nick in prefix of message, example: \"<\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_nick_prefix_suffix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_nick_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "nick_suffix", "string",
- N_("text to display after nick in prefix of message, example: \">\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_nick_prefix_suffix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_paste_bracketed = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "paste_bracketed", "boolean",
- N_("enable terminal \"bracketed paste mode\" (not supported in all "
- "terminals/multiplexers): in this mode, pasted text is bracketed "
- "with control sequences so that WeeChat can differentiate pasted "
- "text from typed-in text (\"ESC[200~\", followed by the pasted text, "
- "followed by \"ESC[201~\")"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_paste_bracketed, NULL, NULL,
- NULL, NULL, NULL);
- config_look_paste_bracketed_timer_delay = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "paste_bracketed_timer_delay", "integer",
- N_("force end of bracketed paste after this delay (in seconds) if the "
- "control sequence for end of bracketed paste (\"ESC[201~\") was not "
- "received in time"),
- NULL, 1, 60, "10", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_paste_max_lines = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "paste_max_lines", "integer",
- N_("max number of lines for paste without asking user "
- "(-1 = disable this feature); this option is used only if the bar "
- "item \"input_paste\" is used in at least one bar (by default it "
- "is used in \"input\" bar)"),
- NULL, -1, INT_MAX, "100", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_prefix[GUI_CHAT_PREFIX_ERROR] = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_error", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("prefix for error messages (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, GUI_CHAT_PREFIX_ERROR_DEFAULT, NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix[GUI_CHAT_PREFIX_NETWORK] = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_network", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("prefix for network messages (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, GUI_CHAT_PREFIX_NETWORK_DEFAULT, NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix[GUI_CHAT_PREFIX_ACTION] = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_action", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("prefix for action messages (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, GUI_CHAT_PREFIX_ACTION_DEFAULT, NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix[GUI_CHAT_PREFIX_JOIN] = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_join", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("prefix for join messages (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, GUI_CHAT_PREFIX_JOIN_DEFAULT, NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix[GUI_CHAT_PREFIX_QUIT] = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_quit", "string",
- /* TRANSLATORS: string "${color:xxx}" must NOT be translated */
- N_("prefix for quit messages (note: content is evaluated, so you can "
- "use colors with format \"${color:xxx}\", see /help eval)"),
- NULL, 0, 0, GUI_CHAT_PREFIX_QUIT_DEFAULT, NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_align = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_align", "integer",
- N_("prefix alignment (none, left, right (default))"),
- "none|left|right", 0, 0, "right", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_align_max = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_align_max", "integer",
- N_("max size for prefix (0 = no max size)"),
- NULL, 0, 128, "0", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_align_min = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_align_min", "integer",
- N_("min size for prefix"),
- NULL, 0, 128, "0", NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix_align_min, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_align_more = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_align_more", "string",
- N_("char to display if prefix is truncated (must be exactly one char "
- "on screen)"),
- NULL, 0, 0, "+", NULL, 0,
- &config_check_prefix_align_more, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_align_more_after = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_align_more_after", "boolean",
- N_("display the truncature char (by default \"+\") after the text (by "
- "replacing the space that should be displayed here); if disabled, "
- "the truncature char replaces last char of text"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_buffer_align = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_buffer_align", "integer",
- N_("prefix alignment for buffer name, when many buffers are merged "
- "with same number (none, left, right (default))"),
- "none|left|right", 0, 0, "right", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_buffer_align_max = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_buffer_align_max", "integer",
- N_("max size for buffer name, when many buffers are merged with same "
- "number (0 = no max size)"),
- NULL, 0, 128, "0", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_buffer_align_more = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_buffer_align_more", "string",
- N_("char to display if buffer name is truncated (when many buffers are "
- "merged with same number) (must be exactly one char on screen)"),
- NULL, 0, 0, "+", NULL, 0,
- &config_check_prefix_buffer_align_more, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_buffer_align_more_after = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_buffer_align_more_after", "boolean",
- N_("display the truncature char (by default \"+\") after the text (by "
- "replacing the space that should be displayed here); if disabled, "
- "the truncature char replaces last char of text"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_same_nick = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_same_nick", "string",
- N_("prefix displayed for a message with same nick as previous "
- "but not next message: use a space \" \" to hide prefix, another "
- "string to display this string instead of prefix, or an empty "
- "string to disable feature (display prefix)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix_same_nick, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_same_nick_middle = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_same_nick_middle", "string",
- N_("prefix displayed for a message with same nick as previous "
- "and next message: use a space \" \" to hide prefix, another "
- "string to display this string instead of prefix, or an empty "
- "string to disable feature (display prefix)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_prefix_same_nick_middle, NULL, NULL,
- NULL, NULL, NULL);
- config_look_prefix_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "prefix_suffix", "string",
- N_("string displayed after prefix"),
- NULL, 0, 0, "|", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_quote_nick_prefix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "quote_nick_prefix", "string",
- N_("text to display before nick when quoting a message (see /help "
- "cursor)"),
- NULL, 0, 0, "<", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_quote_nick_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "quote_nick_suffix", "string",
- N_("text to display after nick when quoting a message (see /help "
- "cursor)"),
- NULL, 0, 0, ">", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_quote_time_format = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "quote_time_format", "string",
- N_("time format when quoting a message (see /help cursor)"),
- NULL, 0, 0, "%H:%M:%S", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_read_marker = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "read_marker", "integer",
- N_("use a marker (line or char) on buffers to show first unread line"),
- "none|line|char",
- 0, 0, "line", NULL, 0,
- NULL, NULL, NULL,
- &config_change_read_marker, NULL, NULL,
- NULL, NULL, NULL);
- config_look_read_marker_always_show = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "read_marker_always_show", "boolean",
- N_("always show read marker, even if it is after last buffer line"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_read_marker_string = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "read_marker_string", "string",
- N_("string used to draw read marker line (string is repeated until "
- "end of line)"),
- NULL, 0, 0, "- ", NULL, 0,
- NULL, NULL, NULL,
- &config_change_read_marker, NULL, NULL,
- NULL, NULL, NULL);
- config_look_read_marker_update_on_buffer_switch = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "read_marker_update_on_buffer_switch", "boolean",
- N_("update the read marker when switching buffers"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_save_config_on_exit = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "save_config_on_exit", "boolean",
- N_("save configuration file on exit"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_save_config_on_exit, NULL, NULL,
- NULL, NULL, NULL);
- config_look_save_config_with_fsync = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "save_config_with_fsync", "boolean",
- N_("use fsync to synchronize the configuration file with the storage "
- "device (see man fsync); this is slower but should prevent any "
- "data loss in case of power failure during the save of "
- "configuration file"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &config_change_save_config_on_exit, NULL, NULL,
- NULL, NULL, NULL);
- config_look_save_layout_on_exit = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "save_layout_on_exit", "integer",
- N_("save layout on exit (buffers, windows, or both)"),
- "none|buffers|windows|all", 0, 0, "none", NULL, 0,
- NULL, NULL, NULL,
- &config_change_save_layout_on_exit, NULL, NULL,
- NULL, NULL, NULL);
- config_look_scroll_amount = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "scroll_amount", "integer",
- N_("how many lines to scroll by with scroll_up and "
- "scroll_down"),
- NULL, 1, INT_MAX, "3", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffer_content, NULL, NULL,
- NULL, NULL, NULL);
- config_look_scroll_bottom_after_switch = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "scroll_bottom_after_switch", "boolean",
- N_("scroll to bottom of window after switch to another buffer (do not "
- "remember scroll position in windows); the scroll is done only for "
- "buffers with formatted content (not free content)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_scroll_page_percent = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "scroll_page_percent", "integer",
- N_("percent of screen to scroll when scrolling one page up or down "
- "(for example 100 means one page, 50 half-page)"),
- NULL, 1, 100, "100", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_search_text_not_found_alert = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "search_text_not_found_alert", "boolean",
- N_("alert user when text sought is not found in buffer"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_separator_horizontal = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "separator_horizontal", "string",
- N_("char used to draw horizontal separators around bars and windows "
- "(empty value will draw a real line with ncurses, but may cause bugs "
- "with URL selection under some terminals); "
- "width on screen must be exactly one char"),
- NULL, 0, 0, "-", NULL, 0,
- &config_check_separator, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_separator_vertical = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "separator_vertical", "string",
- N_("char used to draw vertical separators around bars and windows "
- "(empty value will draw a real line with ncurses); "
- "width on screen must be exactly one char"),
- NULL, 0, 0, "", NULL, 0,
- &config_check_separator, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_tab_width = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "tab_width", "integer",
- N_("number of spaces used to display tabs in messages"),
- NULL, 1, TAB_MAX_WIDTH, "1", NULL, 0,
- NULL, NULL, NULL,
- &config_change_tab_width, NULL, NULL,
- NULL, NULL, NULL);
- config_look_time_format = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "time_format", "string",
- N_("time format for dates converted to strings and displayed in "
- "messages (see man strftime for date/time specifiers)"),
- NULL, 0, 0, "%a, %d %b %Y %T", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_window_auto_zoom = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "window_auto_zoom", "boolean",
- N_("automatically zoom on current window if the terminal becomes too "
- "small to display all windows (use alt-z to unzoom windows when the "
- "terminal is big enough)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_look_window_separator_horizontal = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "window_separator_horizontal", "boolean",
- N_("display an horizontal separator between windows"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_window_separator_vertical = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "window_separator_vertical", "boolean",
- N_("display a vertical separator between windows"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_buffers, NULL, NULL,
- NULL, NULL, NULL);
- config_look_window_title = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "window_title", "string",
- N_("title for window (terminal for Curses GUI), set on startup; "
- "an empty string will keep title unchanged "
- "(note: content is evaluated, see /help eval); example: "
- "\"WeeChat ${info:version}\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_window_title, NULL, NULL,
- NULL, NULL, NULL);
- config_look_word_chars_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "word_chars_highlight", "string",
- N_("comma-separated list of chars (or range of chars) that are "
- "considered part of words for highlights; "
- "each item can be a single char, a range of chars (format: a-z), "
- "a class of wide character (for example \"alnum\", "
- "see man wctype); a \"!\" before the item makes it negative "
- "(ie the char is NOT considered part of words); the value \"*\" "
- "matches any char; unicode chars are allowed with the format "
- "\\u1234, for example \\u00A0 for unbreakable space "
- "(see /help print for supported formats)"),
- NULL, 0, 0, "!\\u00A0,-,_,|,alnum", NULL, 0,
- NULL, NULL, NULL,
- &config_change_word_chars_highlight, NULL, NULL,
- NULL, NULL, NULL);
- config_look_word_chars_input = config_file_new_option (
- weechat_config_file, weechat_config_section_look,
- "word_chars_input", "string",
- N_("comma-separated list of chars (or range of chars) that are "
- "considered part of words for command line; "
- "each item can be a single char, a range of chars (format: a-z), "
- "a class of wide character (for example \"alnum\", "
- "see man wctype); a \"!\" before the item makes it negative "
- "(ie the char is NOT considered part of words); the value \"*\" "
- "matches any char; unicode chars are allowed with the format "
- "\\u1234, for example \\u00A0 for unbreakable space "
- "(see /help print for supported formats)"),
- NULL, 0, 0, "!\\u00A0,-,_,|,alnum", NULL, 0,
- NULL, NULL, NULL,
- &config_change_word_chars_input, NULL, NULL,
- NULL, NULL, NULL);
-
/* palette */
weechat_config_section_palette = config_file_new_section (
weechat_config_file, "palette",
@@ -3978,12 +3986,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
&config_weechat_palette_create_option_cb, NULL, NULL,
&config_weechat_palette_delete_option_cb, NULL, NULL);
- if (!weechat_config_section_palette)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* colors */
weechat_config_section_color = config_file_new_section (
@@ -3994,557 +3996,558 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_color)
+ if (weechat_config_section_color)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ /* bar colors */
+ config_color_bar_more = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "bar_more", "color",
+ N_("text color for \"+\" when scrolling bars"),
+ NULL, -1, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* chat area */
+ config_color_chat = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat", "color",
+ N_("text color for chat"),
+ NULL, GUI_COLOR_CHAT, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_bg", "color",
+ N_("background color for chat"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_buffer", "color",
+ N_("text color for buffer names"),
+ NULL, GUI_COLOR_CHAT_BUFFER, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_channel = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_channel", "color",
+ N_("text color for channel names"),
+ NULL, GUI_COLOR_CHAT_CHANNEL, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_day_change = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_day_change", "color",
+ N_("text color for message displayed when the day has changed"),
+ NULL, GUI_COLOR_CHAT_DAY_CHANGE, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_delimiters = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_delimiters", "color",
+ N_("text color for delimiters"),
+ NULL, GUI_COLOR_CHAT_DELIMITERS, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_highlight", "color",
+ N_("text color for highlighted prefix"),
+ NULL, GUI_COLOR_CHAT_HIGHLIGHT, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_highlight_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_highlight_bg", "color",
+ N_("background color for highlighted prefix"),
+ NULL, -1, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_host = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_host", "color",
+ N_("text color for hostnames"),
+ NULL, GUI_COLOR_CHAT_HOST, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_inactive_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_inactive_buffer", "color",
+ N_("text color for chat when line is inactive (buffer is merged "
+ "with other buffers and is not selected)"),
+ NULL, GUI_COLOR_CHAT_INACTIVE_BUFFER, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_inactive_window = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_inactive_window", "color",
+ N_("text color for chat when window is inactive (not current "
+ "selected window)"),
+ NULL, GUI_COLOR_CHAT_INACTIVE_WINDOW, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick", "color",
+ N_("text color for nicks in chat window: used in some server "
+ "messages and as fallback when a nick color is not found; most "
+ "of times nick color comes from option "
+ "weechat.color.chat_nick_colors"),
+ NULL, GUI_COLOR_CHAT_NICK, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_colors = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_colors", "string",
+ /* TRANSLATORS: please do not translate "lightred:blue" */
+ N_("text color for nicks (comma separated list of colors, "
+ "background is allowed with format: \"fg:bg\", for example: "
+ "\"lightred:blue\")"),
+ NULL, 0, 0, "cyan,magenta,green,brown,lightblue,default,lightcyan,"
+ "lightmagenta,lightgreen,blue", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_nick_colors, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_offline = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_offline", "color",
+ N_("text color for offline nick (not in nicklist any more); this "
+ "color is used only if option weechat.look.color_nick_offline is "
+ "enabled"),
+ NULL, GUI_COLOR_CHAT_NICK_OFFLINE, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_offline_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_offline_highlight", "color",
+ N_("text color for offline nick with highlight; this color is used "
+ "only if option weechat.look.color_nick_offline is enabled"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_offline_highlight_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_offline_highlight_bg", "color",
+ N_("background color for offline nick with highlight; this color is "
+ "used only if option weechat.look.color_nick_offline is enabled"),
+ NULL, -1, 0, "blue", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_other = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_other", "color",
+ N_("text color for other nick in private buffer"),
+ NULL, GUI_COLOR_CHAT_NICK_OTHER, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_prefix = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_prefix", "color",
+ N_("color for nick prefix (string displayed before nick in prefix)"),
+ NULL, GUI_COLOR_CHAT_NICK_PREFIX, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_self = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_self", "color",
+ N_("text color for local nick in chat window"),
+ NULL, GUI_COLOR_CHAT_NICK_SELF, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_nick_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_nick_suffix", "color",
+ N_("color for nick suffix (string displayed after nick in prefix)"),
+ NULL, GUI_COLOR_CHAT_NICK_SUFFIX, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix[GUI_CHAT_PREFIX_ERROR] = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_error", "color",
+ N_("text color for error prefix"),
+ NULL, GUI_COLOR_CHAT_PREFIX_ERROR, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_buffer", "color",
+ N_("text color for buffer name (before prefix, when many buffers "
+ "are merged with same number)"),
+ NULL, GUI_COLOR_CHAT_PREFIX_BUFFER, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix_buffer_inactive_buffer = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_buffer_inactive_buffer", "color",
+ N_("text color for inactive buffer name (before prefix, when many "
+ "buffers are merged with same number and if buffer is not "
+ "selected)"),
+ NULL, GUI_COLOR_CHAT_PREFIX_BUFFER_INACTIVE_BUFFER, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix[GUI_CHAT_PREFIX_NETWORK] = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_network", "color",
+ N_("text color for network prefix"),
+ NULL, GUI_COLOR_CHAT_PREFIX_NETWORK, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix[GUI_CHAT_PREFIX_ACTION] = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_action", "color",
+ N_("text color for action prefix"),
+ NULL, GUI_COLOR_CHAT_PREFIX_ACTION, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix[GUI_CHAT_PREFIX_JOIN] = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_join", "color",
+ N_("text color for join prefix"),
+ NULL, GUI_COLOR_CHAT_PREFIX_JOIN, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix[GUI_CHAT_PREFIX_QUIT] = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_quit", "color",
+ N_("text color for quit prefix"),
+ NULL, GUI_COLOR_CHAT_PREFIX_QUIT, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix_more = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_more", "color",
+ N_("text color for \"+\" when prefix is too long"),
+ NULL, GUI_COLOR_CHAT_PREFIX_MORE, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_prefix_suffix = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_prefix_suffix", "color",
+ N_("text color for suffix (after prefix)"),
+ NULL, GUI_COLOR_CHAT_PREFIX_SUFFIX, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_read_marker = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_read_marker", "color",
+ N_("text color for unread data marker"),
+ NULL, GUI_COLOR_CHAT_READ_MARKER, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_read_marker_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_read_marker_bg", "color",
+ N_("background color for unread data marker"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_server = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_server", "color",
+ N_("text color for server names"),
+ NULL, GUI_COLOR_CHAT_SERVER, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_tags = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_tags", "color",
+ N_("text color for tags after messages (displayed with command "
+ "/debug tags)"),
+ NULL, GUI_COLOR_CHAT_TAGS, 0, "red", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_text_found = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_text_found", "color",
+ N_("text color for marker on lines where text sought is found"),
+ NULL, GUI_COLOR_CHAT_TEXT_FOUND, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_text_found_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_text_found_bg", "color",
+ N_("background color for marker on lines where text sought is "
+ "found"),
+ NULL, -1, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_time = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_time", "color",
+ N_("text color for time in chat window"),
+ NULL, GUI_COLOR_CHAT_TIME, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_time_delimiters = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_time_delimiters", "color",
+ N_("text color for time delimiters"),
+ NULL, GUI_COLOR_CHAT_TIME_DELIMITERS, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_value = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_value", "color",
+ N_("text color for values"),
+ NULL, GUI_COLOR_CHAT_VALUE, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_chat_value_null = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "chat_value_null", "color",
+ N_("text color for null values (undefined)"),
+ NULL, GUI_COLOR_CHAT_VALUE_NULL, 0, "blue", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* emphasis (chat/bars) */
+ config_color_emphasized = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "emphasized", "color",
+ N_("text color for emphasized text (for example when searching "
+ "text); this option is used only if option "
+ "weechat.look.emphasized_attributes is an empty string "
+ "(default value)"),
+ NULL, GUI_COLOR_EMPHASIS, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_emphasized_bg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "emphasized_bg", "color",
+ N_("background color for emphasized text (for example when searching "
+ "text); used only if option weechat.look.emphasized_attributes "
+ "is an empty string (default value)"),
+ NULL, -1, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* input bar */
+ config_color_input_actions = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "input_actions", "color",
+ N_("text color for actions in input line"),
+ NULL, -1, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_input_text_not_found = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "input_text_not_found", "color",
+ N_("text color for unsuccessful text search in input line"),
+ NULL, -1, 0, "red", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* items */
+ config_color_item_away = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "item_away", "color",
+ N_("text color for away item"),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_item_away, NULL, NULL,
+ NULL, NULL, NULL);
+ /* nicklist bar */
+ config_color_nicklist_away = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "nicklist_away", "color",
+ N_("text color for away nicknames"),
+ NULL, -1, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_nicklist_group = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "nicklist_group", "color",
+ N_("text color for groups in nicklist"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* general color settings */
+ config_color_separator = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "separator", "color",
+ N_("color for window separators (when split) and separators beside "
+ "bars (like nicklist)"),
+ NULL, GUI_COLOR_SEPARATOR, 0, "blue", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ /* status bar */
+ config_color_status_count_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_count_highlight", "color",
+ N_("text color for count of highlight messages in hotlist "
+ "(status bar)"),
+ NULL, -1, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_count_msg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_count_msg", "color",
+ N_("text color for count of messages in hotlist (status bar)"),
+ NULL, -1, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_count_other = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_count_other", "color",
+ N_("text color for count of other messages in hotlist (status bar)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_count_private = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_count_private", "color",
+ N_("text color for count of private messages in hotlist "
+ "(status bar)"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_data_highlight = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_data_highlight", "color",
+ N_("text color for buffer with highlight (status bar)"),
+ NULL, -1, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_data_msg = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_data_msg", "color",
+ N_("text color for buffer with new messages (status bar)"),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_data_other = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_data_other", "color",
+ N_("text color for buffer with new data (not messages) "
+ "(status bar)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_data_private = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_data_private", "color",
+ N_("text color for buffer with private message (status bar)"),
+ NULL, -1, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_filter = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_filter", "color",
+ N_("text color for filter indicator in status bar"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_more = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_more", "color",
+ N_("text color for buffer with new data (status bar)"),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_mouse = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_mouse", "color",
+ N_("text color for mouse indicator in status bar"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_name = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_name", "color",
+ N_("text color for current buffer name in status bar"),
+ NULL, -1, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_name_ssl = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_name_ssl", "color",
+ N_("text color for current buffer name in status bar, if data are "
+ "secured with a protocol like SSL"),
+ NULL, -1, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_nicklist_count = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_nicklist_count", "color",
+ N_("text color for number of nicks in nicklist (status bar)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_number = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_number", "color",
+ N_("text color for current buffer number in status bar"),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
+ config_color_status_time = config_file_new_option (
+ weechat_config_file, weechat_config_section_color,
+ "status_time", "color",
+ N_("text color for time (status bar)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_color, NULL, NULL,
+ NULL, NULL, NULL);
}
- /* bar colors */
- config_color_bar_more = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "bar_more", "color",
- N_("text color for \"+\" when scrolling bars"),
- NULL, -1, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* chat area */
- config_color_chat = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat", "color",
- N_("text color for chat"),
- NULL, GUI_COLOR_CHAT, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_bg", "color",
- N_("background color for chat"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_buffer", "color",
- N_("text color for buffer names"),
- NULL, GUI_COLOR_CHAT_BUFFER, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_channel = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_channel", "color",
- N_("text color for channel names"),
- NULL, GUI_COLOR_CHAT_CHANNEL, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_day_change = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_day_change", "color",
- N_("text color for message displayed when the day has changed"),
- NULL, GUI_COLOR_CHAT_DAY_CHANGE, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_delimiters = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_delimiters", "color",
- N_("text color for delimiters"),
- NULL, GUI_COLOR_CHAT_DELIMITERS, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_highlight", "color",
- N_("text color for highlighted prefix"),
- NULL, GUI_COLOR_CHAT_HIGHLIGHT, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_highlight_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_highlight_bg", "color",
- N_("background color for highlighted prefix"),
- NULL, -1, 0, "magenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_host = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_host", "color",
- N_("text color for hostnames"),
- NULL, GUI_COLOR_CHAT_HOST, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_inactive_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_inactive_buffer", "color",
- N_("text color for chat when line is inactive (buffer is merged with "
- "other buffers and is not selected)"),
- NULL, GUI_COLOR_CHAT_INACTIVE_BUFFER, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_inactive_window = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_inactive_window", "color",
- N_("text color for chat when window is inactive (not current selected "
- "window)"),
- NULL, GUI_COLOR_CHAT_INACTIVE_WINDOW, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick", "color",
- N_("text color for nicks in chat window: used in some server messages "
- "and as fallback when a nick color is not found; most of times "
- "nick color comes from option weechat.color.chat_nick_colors"),
- NULL, GUI_COLOR_CHAT_NICK, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_colors = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_colors", "string",
- /* TRANSLATORS: please do not translate "lightred:blue" */
- N_("text color for nicks (comma separated list of colors, background "
- "is allowed with format: \"fg:bg\", for example: "
- "\"lightred:blue\")"),
- NULL, 0, 0, "cyan,magenta,green,brown,lightblue,default,lightcyan,"
- "lightmagenta,lightgreen,blue", NULL, 0,
- NULL, NULL, NULL,
- &config_change_nick_colors, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_offline = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_offline", "color",
- N_("text color for offline nick (not in nicklist any more); this "
- "color is used only if option weechat.look.color_nick_offline is "
- "enabled"),
- NULL, GUI_COLOR_CHAT_NICK_OFFLINE, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_offline_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_offline_highlight", "color",
- N_("text color for offline nick with highlight; this color is used "
- "only if option weechat.look.color_nick_offline is enabled"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_offline_highlight_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_offline_highlight_bg", "color",
- N_("background color for offline nick with highlight; this color is "
- "used only if option weechat.look.color_nick_offline is enabled"),
- NULL, -1, 0, "blue", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_other = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_other", "color",
- N_("text color for other nick in private buffer"),
- NULL, GUI_COLOR_CHAT_NICK_OTHER, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_prefix = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_prefix", "color",
- N_("color for nick prefix (string displayed before nick in prefix)"),
- NULL, GUI_COLOR_CHAT_NICK_PREFIX, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_self = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_self", "color",
- N_("text color for local nick in chat window"),
- NULL, GUI_COLOR_CHAT_NICK_SELF, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_nick_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_nick_suffix", "color",
- N_("color for nick suffix (string displayed after nick in prefix)"),
- NULL, GUI_COLOR_CHAT_NICK_SUFFIX, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix[GUI_CHAT_PREFIX_ERROR] = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_error", "color",
- N_("text color for error prefix"),
- NULL, GUI_COLOR_CHAT_PREFIX_ERROR, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_buffer", "color",
- N_("text color for buffer name (before prefix, when many buffers are "
- "merged with same number)"),
- NULL, GUI_COLOR_CHAT_PREFIX_BUFFER, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix_buffer_inactive_buffer = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_buffer_inactive_buffer", "color",
- N_("text color for inactive buffer name (before prefix, when many "
- "buffers are merged with same number and if buffer is not "
- "selected)"),
- NULL, GUI_COLOR_CHAT_PREFIX_BUFFER_INACTIVE_BUFFER, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix[GUI_CHAT_PREFIX_NETWORK] = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_network", "color",
- N_("text color for network prefix"),
- NULL, GUI_COLOR_CHAT_PREFIX_NETWORK, 0, "magenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix[GUI_CHAT_PREFIX_ACTION] = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_action", "color",
- N_("text color for action prefix"),
- NULL, GUI_COLOR_CHAT_PREFIX_ACTION, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix[GUI_CHAT_PREFIX_JOIN] = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_join", "color",
- N_("text color for join prefix"),
- NULL, GUI_COLOR_CHAT_PREFIX_JOIN, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix[GUI_CHAT_PREFIX_QUIT] = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_quit", "color",
- N_("text color for quit prefix"),
- NULL, GUI_COLOR_CHAT_PREFIX_QUIT, 0, "lightred", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix_more = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_more", "color",
- N_("text color for \"+\" when prefix is too long"),
- NULL, GUI_COLOR_CHAT_PREFIX_MORE, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_prefix_suffix = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_prefix_suffix", "color",
- N_("text color for suffix (after prefix)"),
- NULL, GUI_COLOR_CHAT_PREFIX_SUFFIX, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_read_marker = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_read_marker", "color",
- N_("text color for unread data marker"),
- NULL, GUI_COLOR_CHAT_READ_MARKER, 0, "magenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_read_marker_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_read_marker_bg", "color",
- N_("background color for unread data marker"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_server = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_server", "color",
- N_("text color for server names"),
- NULL, GUI_COLOR_CHAT_SERVER, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_tags = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_tags", "color",
- N_("text color for tags after messages (displayed with command /debug "
- "tags)"),
- NULL, GUI_COLOR_CHAT_TAGS, 0, "red", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_text_found = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_text_found", "color",
- N_("text color for marker on lines where text sought is found"),
- NULL, GUI_COLOR_CHAT_TEXT_FOUND, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_text_found_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_text_found_bg", "color",
- N_("background color for marker on lines where text sought is found"),
- NULL, -1, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_time = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_time", "color",
- N_("text color for time in chat window"),
- NULL, GUI_COLOR_CHAT_TIME, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_time_delimiters = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_time_delimiters", "color",
- N_("text color for time delimiters"),
- NULL, GUI_COLOR_CHAT_TIME_DELIMITERS, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_value = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_value", "color",
- N_("text color for values"),
- NULL, GUI_COLOR_CHAT_VALUE, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_chat_value_null = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "chat_value_null", "color",
- N_("text color for null values (undefined)"),
- NULL, GUI_COLOR_CHAT_VALUE_NULL, 0, "blue", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* emphasis (chat/bars) */
- config_color_emphasized = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "emphasized", "color",
- N_("text color for emphasized text (for example when searching text); "
- "this option is used only if option weechat.look.emphasized_attributes "
- "is an empty string (default value)"),
- NULL, GUI_COLOR_EMPHASIS, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_emphasized_bg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "emphasized_bg", "color",
- N_("background color for emphasized text (for example when searching "
- "text); used only if option weechat.look.emphasized_attributes is an "
- "empty string (default value)"),
- NULL, -1, 0, "magenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* input bar */
- config_color_input_actions = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "input_actions", "color",
- N_("text color for actions in input line"),
- NULL, -1, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_input_text_not_found = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "input_text_not_found", "color",
- N_("text color for unsuccessful text search in input line"),
- NULL, -1, 0, "red", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* items */
- config_color_item_away = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "item_away", "color",
- N_("text color for away item"),
- NULL, -1, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_item_away, NULL, NULL,
- NULL, NULL, NULL);
- /* nicklist bar */
- config_color_nicklist_away = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "nicklist_away", "color",
- N_("text color for away nicknames"),
- NULL, -1, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_nicklist_group = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "nicklist_group", "color",
- N_("text color for groups in nicklist"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* general color settings */
- config_color_separator = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "separator", "color",
- N_("color for window separators (when split) and separators beside bars "
- "(like nicklist)"),
- NULL, GUI_COLOR_SEPARATOR, 0, "blue", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- /* status bar */
- config_color_status_count_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_count_highlight", "color",
- N_("text color for count of highlight messages in hotlist (status bar)"),
- NULL, -1, 0, "magenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_count_msg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_count_msg", "color",
- N_("text color for count of messages in hotlist (status bar)"),
- NULL, -1, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_count_other = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_count_other", "color",
- N_("text color for count of other messages in hotlist (status bar)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_count_private = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_count_private", "color",
- N_("text color for count of private messages in hotlist (status bar)"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_data_highlight = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_data_highlight", "color",
- N_("text color for buffer with highlight (status bar)"),
- NULL, -1, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_data_msg = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_data_msg", "color",
- N_("text color for buffer with new messages (status bar)"),
- NULL, -1, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_data_other = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_data_other", "color",
- N_("text color for buffer with new data (not messages) "
- "(status bar)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_data_private = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_data_private", "color",
- N_("text color for buffer with private message (status bar)"),
- NULL, -1, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_filter = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_filter", "color",
- N_("text color for filter indicator in status bar"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_more = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_more", "color",
- N_("text color for buffer with new data (status bar)"),
- NULL, -1, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_mouse = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_mouse", "color",
- N_("text color for mouse indicator in status bar"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_name = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_name", "color",
- N_("text color for current buffer name in status bar"),
- NULL, -1, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_name_ssl = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_name_ssl", "color",
- N_("text color for current buffer name in status bar, if data are "
- "secured with a protocol like SSL"),
- NULL, -1, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_nicklist_count = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_nicklist_count", "color",
- N_("text color for number of nicks in nicklist (status bar)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_number = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_number", "color",
- N_("text color for current buffer number in status bar"),
- NULL, -1, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
- config_color_status_time = config_file_new_option (
- weechat_config_file, weechat_config_section_color,
- "status_time", "color",
- N_("text color for time (status bar)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &config_change_color, NULL, NULL,
- NULL, NULL, NULL);
-
/* completion */
weechat_config_section_completion = config_file_new_section (
weechat_config_file, "completion",
@@ -4554,115 +4557,111 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_completion)
+ if (weechat_config_section_completion)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_completion_base_word_until_cursor = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "base_word_until_cursor", "boolean",
+ N_("if enabled, the base word to complete ends at char before cursor; "
+ "otherwise the base word ends at first space after cursor"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_command_inline = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "command_inline", "boolean",
+ N_("if enabled, the commands inside command line are completed (the "
+ "command at beginning of line has higher priority and is used "
+ "first); note: when this option is enabled, there is no more "
+ "automatic completion of paths beginning with \"/\" (outside "
+ "commands arguments)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_default_template = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "default_template", "string",
+ N_("default completion template (please see documentation for "
+ "template codes and values: plugin API reference, function "
+ "\"weechat_hook_command\")"),
+ NULL, 0, 0, "%(nicks)|%(irc_channels)", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_nick_add_space = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "nick_add_space", "boolean",
+ N_("add space after nick completion (when nick is not first word "
+ "on command line)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_nick_case_sensitive = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "nick_case_sensitive", "boolean",
+ N_("case sensitive completion for nicks"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_nick_completer = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "nick_completer", "string",
+ N_("string inserted after nick completion (when nick is first word "
+ "on command line)"),
+ NULL, 0, 0, ": ", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_nick_first_only = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "nick_first_only", "boolean",
+ N_("complete only with first nick found"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_nick_ignore_chars = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "nick_ignore_chars", "string",
+ N_("chars ignored for nick completion"),
+ NULL, 0, 0, "[]`_-^", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_alert = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_alert", "boolean",
+ N_("send alert (BEL) when a partial completion occurs"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_command = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_command", "boolean",
+ N_("partially complete command names (stop when many commands found "
+ "begin with same letters)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_command_arg = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_command_arg", "boolean",
+ N_("partially complete command arguments (stop when many arguments "
+ "found begin with same prefix)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_count = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_count", "boolean",
+ N_("display count for each partial completion in bar item"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_other = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_other", "boolean",
+ N_("partially complete outside commands (stop when many words found "
+ "begin with same letters)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_completion_partial_completion_templates = config_file_new_option (
+ weechat_config_file, weechat_config_section_completion,
+ "partial_completion_templates", "string",
+ N_("comma-separated list of templates for which partial completion "
+ "is enabled by default (with Tab key instead of shift-Tab); "
+ "the list of templates is in documentation: plugin API reference, "
+ "function \"weechat_hook_command\""),
+ NULL, 0, 0, "config_options", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_completion_partial_completion_templates, NULL, NULL,
+ NULL, NULL, NULL);
}
- config_completion_base_word_until_cursor = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "base_word_until_cursor", "boolean",
- N_("if enabled, the base word to complete ends at char before cursor; "
- "otherwise the base word ends at first space after cursor"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_command_inline = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "command_inline", "boolean",
- N_("if enabled, the commands inside command line are completed (the "
- "command at beginning of line has higher priority and is used "
- "first); note: when this option is enabled, there is no more "
- "automatic completion of paths beginning with \"/\" (outside "
- "commands arguments)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_default_template = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "default_template", "string",
- N_("default completion template (please see documentation for template "
- "codes and values: plugin API reference, function "
- "\"weechat_hook_command\")"),
- NULL, 0, 0, "%(nicks)|%(irc_channels)", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_nick_add_space = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "nick_add_space", "boolean",
- N_("add space after nick completion (when nick is not first word on "
- "command line)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_nick_case_sensitive = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "nick_case_sensitive", "boolean",
- N_("case sensitive completion for nicks"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_nick_completer = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "nick_completer", "string",
- N_("string inserted after nick completion (when nick is first word on "
- "command line)"),
- NULL, 0, 0, ": ", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_nick_first_only = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "nick_first_only", "boolean",
- N_("complete only with first nick found"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_nick_ignore_chars = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "nick_ignore_chars", "string",
- N_("chars ignored for nick completion"),
- NULL, 0, 0, "[]`_-^", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_alert = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_alert", "boolean",
- N_("send alert (BEL) when a partial completion occurs"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_command = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_command", "boolean",
- N_("partially complete command names (stop when many commands found "
- "begin with same letters)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_command_arg = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_command_arg", "boolean",
- N_("partially complete command arguments (stop when many arguments "
- "found begin with same prefix)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_count = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_count", "boolean",
- N_("display count for each partial completion in bar item"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_other = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_other", "boolean",
- N_("partially complete outside commands (stop when many words found "
- "begin with same letters)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_completion_partial_completion_templates = config_file_new_option (
- weechat_config_file, weechat_config_section_completion,
- "partial_completion_templates", "string",
- N_("comma-separated list of templates for which partial completion is "
- "enabled by default (with Tab key instead of shift-Tab); "
- "the list of templates is in documentation: plugin API reference, "
- "function \"weechat_hook_command\""),
- NULL, 0, 0, "config_options", NULL, 0,
- NULL, NULL, NULL,
- &config_change_completion_partial_completion_templates, NULL, NULL,
- NULL, NULL, NULL);
-
/* history */
weechat_config_section_history = config_file_new_section (
weechat_config_file, "history",
@@ -4672,51 +4671,47 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_history)
+ if (weechat_config_section_history)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_history_display_default = config_file_new_option (
+ weechat_config_file, weechat_config_section_history,
+ "display_default", "integer",
+ N_("maximum number of commands to display by default in "
+ "history listing (0 = unlimited)"),
+ NULL, 0, INT_MAX, "5", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_history_max_buffer_lines_minutes = config_file_new_option (
+ weechat_config_file, weechat_config_section_history,
+ "max_buffer_lines_minutes", "integer",
+ N_("maximum number of minutes in history per buffer "
+ "(0 = unlimited); examples: 1440 = one day, 10080 = one week, "
+ "43200 = one month, 525600 = one year; use 0 ONLY if option "
+ "weechat.history.max_buffer_lines_number is NOT set to 0"),
+ NULL, 0, INT_MAX, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_history_max_buffer_lines_number = config_file_new_option (
+ weechat_config_file, weechat_config_section_history,
+ "max_buffer_lines_number", "integer",
+ N_("maximum number of lines in history per buffer "
+ "(0 = unlimited); use 0 ONLY if option "
+ "weechat.history.max_buffer_lines_minutes is NOT set to 0"),
+ NULL, 0, INT_MAX, "4096", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_history_max_commands = config_file_new_option (
+ weechat_config_file, weechat_config_section_history,
+ "max_commands", "integer",
+ N_("maximum number of user commands in history (0 = "
+ "unlimited, NOT RECOMMENDED: no limit in memory usage)"),
+ NULL, 0, INT_MAX, "100", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_history_max_visited_buffers = config_file_new_option (
+ weechat_config_file, weechat_config_section_history,
+ "max_visited_buffers", "integer",
+ N_("maximum number of visited buffers to keep in memory"),
+ NULL, 0, 1000, "50", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- config_history_display_default = config_file_new_option (
- weechat_config_file, weechat_config_section_history,
- "display_default", "integer",
- N_("maximum number of commands to display by default in "
- "history listing (0 = unlimited)"),
- NULL, 0, INT_MAX, "5", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_history_max_buffer_lines_minutes = config_file_new_option (
- weechat_config_file, weechat_config_section_history,
- "max_buffer_lines_minutes", "integer",
- N_("maximum number of minutes in history per buffer "
- "(0 = unlimited); examples: 1440 = one day, 10080 = one week, "
- "43200 = one month, 525600 = one year; use 0 ONLY if option "
- "weechat.history.max_buffer_lines_number is NOT set to 0"),
- NULL, 0, INT_MAX, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_history_max_buffer_lines_number = config_file_new_option (
- weechat_config_file, weechat_config_section_history,
- "max_buffer_lines_number", "integer",
- N_("maximum number of lines in history per buffer "
- "(0 = unlimited); use 0 ONLY if option "
- "weechat.history.max_buffer_lines_minutes is NOT set to 0"),
- NULL, 0, INT_MAX, "4096", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_history_max_commands = config_file_new_option (
- weechat_config_file, weechat_config_section_history,
- "max_commands", "integer",
- N_("maximum number of user commands in history (0 = "
- "unlimited, NOT RECOMMENDED: no limit in memory usage)"),
- NULL, 0, INT_MAX, "100", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_history_max_visited_buffers = config_file_new_option (
- weechat_config_file, weechat_config_section_history,
- "max_visited_buffers", "integer",
- N_("maximum number of visited buffers to keep in memory"),
- NULL, 0, 1000, "50", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* proxies */
weechat_config_section_proxy = config_file_new_section (
weechat_config_file, "proxy",
@@ -4726,12 +4721,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_proxy)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* network */
weechat_config_section_network = config_file_new_section (
@@ -4742,58 +4731,54 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_network)
+ if (weechat_config_section_network)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_network_connection_timeout = config_file_new_option (
+ weechat_config_file, weechat_config_section_network,
+ "connection_timeout", "integer",
+ N_("timeout (in seconds) for connection to a remote host (made in a "
+ "child process)"),
+ NULL, 1, INT_MAX, "60", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_network_gnutls_ca_system = config_file_new_option (
+ weechat_config_file, weechat_config_section_network,
+ "gnutls_ca_system", "boolean",
+ N_("load system's default trusted certificate authorities on startup; "
+ "this can be turned off to save some memory only if you are not "
+ "using SSL connections at all"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_network_gnutls_ca, NULL, NULL,
+ NULL, NULL, NULL);
+ config_network_gnutls_ca_user = config_file_new_option (
+ weechat_config_file, weechat_config_section_network,
+ "gnutls_ca_user", "string",
+ N_("extra file(s) with certificate authorities; multiple files must "
+ "be separated by colons "
+ "(each path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_network_gnutls_ca, NULL, NULL,
+ NULL, NULL, NULL);
+ config_network_gnutls_handshake_timeout = config_file_new_option (
+ weechat_config_file, weechat_config_section_network,
+ "gnutls_handshake_timeout", "integer",
+ N_("timeout (in seconds) for gnutls handshake"),
+ NULL, 1, INT_MAX, "30", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_network_proxy_curl = config_file_new_option (
+ weechat_config_file, weechat_config_section_network,
+ "proxy_curl", "string",
+ N_("name of proxy used for download of URLs with Curl (used to "
+ "download list of scripts and in scripts calling function "
+ "hook_process); the proxy must be defined with command /proxy"),
+ NULL, 0, 0, "", NULL, 0,
+ &config_check_proxy_curl, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
}
- config_network_connection_timeout = config_file_new_option (
- weechat_config_file, weechat_config_section_network,
- "connection_timeout", "integer",
- N_("timeout (in seconds) for connection to a remote host (made in a "
- "child process)"),
- NULL, 1, INT_MAX, "60", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_network_gnutls_ca_system = config_file_new_option (
- weechat_config_file, weechat_config_section_network,
- "gnutls_ca_system", "boolean",
- N_("load system's default trusted certificate authorities on startup; "
- "this can be turned off to save some memory only if you are not "
- "using SSL connections at all"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &config_change_network_gnutls_ca, NULL, NULL,
- NULL, NULL, NULL);
- config_network_gnutls_ca_user = config_file_new_option (
- weechat_config_file, weechat_config_section_network,
- "gnutls_ca_user", "string",
- N_("extra file(s) with certificate authorities; multiple files must "
- "be separated by colons "
- "(each path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &config_change_network_gnutls_ca, NULL, NULL,
- NULL, NULL, NULL);
- config_network_gnutls_handshake_timeout = config_file_new_option (
- weechat_config_file, weechat_config_section_network,
- "gnutls_handshake_timeout", "integer",
- N_("timeout (in seconds) for gnutls handshake"),
- NULL, 1, INT_MAX, "30", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_network_proxy_curl = config_file_new_option (
- weechat_config_file, weechat_config_section_network,
- "proxy_curl", "string",
- N_("name of proxy used for download of URLs with Curl (used to download "
- "list of scripts and in scripts calling function hook_process); the "
- "proxy must be defined with command /proxy"),
- NULL, 0, 0, "", NULL, 0,
- &config_check_proxy_curl, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
-
/* plugin */
weechat_config_section_plugin = config_file_new_section (
weechat_config_file, "plugin",
@@ -4803,46 +4788,42 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_plugin)
+ if (weechat_config_section_plugin)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_plugin_autoload = config_file_new_option (
+ weechat_config_file, weechat_config_section_plugin,
+ "autoload", "string",
+ N_("comma separated list of plugins to load automatically "
+ "at startup, \"*\" means all plugins found, a name beginning with "
+ "\"!\" is a negative value to prevent a plugin from being loaded, "
+ "wildcard \"*\" is allowed in names (examples: \"*\" or "
+ "\"*,!lua,!tcl\")"),
+ NULL, 0, 0, "*", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_plugin_extension = config_file_new_option (
+ weechat_config_file, weechat_config_section_plugin,
+ "extension", "string",
+ N_("comma separated list of file name extensions for plugins"),
+ NULL, 0, 0, ".so,.dll", NULL, 0,
+ NULL, NULL, NULL,
+ &config_change_plugin_extension, NULL, NULL,
+ NULL, NULL, NULL);
+ config_plugin_path = config_file_new_option (
+ weechat_config_file, weechat_config_section_plugin,
+ "path", "string",
+ N_("path for searching plugins "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_data_dir}/plugins", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_plugin_save_config_on_unload = config_file_new_option (
+ weechat_config_file, weechat_config_section_plugin,
+ "save_config_on_unload", "boolean",
+ N_("save configuration files when unloading plugins"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- config_plugin_autoload = config_file_new_option (
- weechat_config_file, weechat_config_section_plugin,
- "autoload", "string",
- N_("comma separated list of plugins to load automatically "
- "at startup, \"*\" means all plugins found, a name beginning with "
- "\"!\" is a negative value to prevent a plugin from being loaded, "
- "wildcard \"*\" is allowed in names (examples: \"*\" or "
- "\"*,!lua,!tcl\")"),
- NULL, 0, 0, "*", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_plugin_extension = config_file_new_option (
- weechat_config_file, weechat_config_section_plugin,
- "extension", "string",
- N_("comma separated list of file name extensions for plugins"),
- NULL, 0, 0, ".so,.dll", NULL, 0,
- NULL, NULL, NULL,
- &config_change_plugin_extension, NULL, NULL,
- NULL, NULL, NULL);
- config_plugin_path = config_file_new_option (
- weechat_config_file, weechat_config_section_plugin,
- "path", "string",
- N_("path for searching plugins "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_data_dir}/plugins", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_plugin_save_config_on_unload = config_file_new_option (
- weechat_config_file, weechat_config_section_plugin,
- "save_config_on_unload", "boolean",
- N_("save configuration files when unloading plugins"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* signal */
weechat_config_section_signal = config_file_new_section (
weechat_config_file, "signal",
@@ -4852,55 +4833,51 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_signal)
+ if (weechat_config_section_signal)
{
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
+ config_signal_sighup = config_file_new_option (
+ weechat_config_file, weechat_config_section_signal,
+ "sighup", "string",
+ N_("command to execute when the signal is received, "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0,
+ "${if:${info:weechat_headless}?/reload:/quit -yes}", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_signal_sigquit = config_file_new_option (
+ weechat_config_file, weechat_config_section_signal,
+ "sigquit", "string",
+ N_("command to execute when the signal is received, "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "/quit -yes", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_signal_sigterm = config_file_new_option (
+ weechat_config_file, weechat_config_section_signal,
+ "sigterm", "string",
+ N_("command to execute when the signal is received, "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "/quit -yes", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_signal_sigusr1 = config_file_new_option (
+ weechat_config_file, weechat_config_section_signal,
+ "sigusr1", "string",
+ N_("command to execute when the signal is received, "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ config_signal_sigusr2 = config_file_new_option (
+ weechat_config_file, weechat_config_section_signal,
+ "sigusr2", "string",
+ N_("command to execute when the signal is received, "
+ "multiple commands can be separated by semicolons "
+ "(note: commands are evaluated, see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- config_signal_sighup = config_file_new_option (
- weechat_config_file, weechat_config_section_signal,
- "sighup", "string",
- N_("command to execute when the signal is received, "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0,
- "${if:${info:weechat_headless}?/reload:/quit -yes}", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_signal_sigquit = config_file_new_option (
- weechat_config_file, weechat_config_section_signal,
- "sigquit", "string",
- N_("command to execute when the signal is received, "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "/quit -yes", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_signal_sigterm = config_file_new_option (
- weechat_config_file, weechat_config_section_signal,
- "sigterm", "string",
- N_("command to execute when the signal is received, "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "/quit -yes", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_signal_sigusr1 = config_file_new_option (
- weechat_config_file, weechat_config_section_signal,
- "sigusr1", "string",
- N_("command to execute when the signal is received, "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- config_signal_sigusr2 = config_file_new_option (
- weechat_config_file, weechat_config_section_signal,
- "sigusr2", "string",
- N_("command to execute when the signal is received, "
- "multiple commands can be separated by semicolons "
- "(note: commands are evaluated, see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* bars */
weechat_config_section_bar = config_file_new_section (
weechat_config_file, "bar",
@@ -4910,12 +4887,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_bar)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* custom bar items */
weechat_config_section_custom_bar_item = config_file_new_section (
@@ -4926,12 +4897,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_custom_bar_item)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* layout */
weechat_config_section_layout = config_file_new_section (
@@ -4942,12 +4907,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_layout)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* notify */
weechat_config_section_notify = config_file_new_section (
@@ -4958,12 +4917,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
&config_weechat_notify_create_option_cb, NULL, NULL,
&config_weechat_notify_delete_option_cb, NULL, NULL);
- if (!weechat_config_section_notify)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* filters */
weechat_config_section_filter = config_file_new_section (
@@ -4974,12 +4927,6 @@ config_weechat_init_options ()
&config_weechat_filter_write_cb, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!weechat_config_section_filter)
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
/* keys */
for (context = 0; context < GUI_KEY_NUM_CONTEXTS; context++)
@@ -4998,12 +4945,6 @@ config_weechat_init_options ()
NULL, NULL, NULL,
&config_weechat_key_create_option_cb, NULL, NULL,
&config_weechat_key_delete_option_cb, NULL, NULL);
- if (!weechat_config_section_key[context])
- {
- config_file_free (weechat_config_file);
- weechat_config_file = NULL;
- return 0;
- }
}
return 1;
diff --git a/src/core/wee-secure-config.c b/src/core/wee-secure-config.c
index d3cef343f..d55c61464 100644
--- a/src/core/wee-secure-config.c
+++ b/src/core/wee-secure-config.c
@@ -40,6 +40,9 @@
struct t_config_file *secure_config_file = NULL;
+struct t_config_section *secure_config_section_crypt = NULL;
+struct t_config_section *secure_config_section_data = NULL;
+
struct t_config_option *secure_config_crypt_cipher = NULL;
struct t_config_option *secure_config_crypt_hash_algo = NULL;
struct t_config_option *secure_config_crypt_passphrase_command = NULL;
@@ -444,68 +447,64 @@ secure_config_data_write_cb (const void *pointer, void *data,
int
secure_config_init_options ()
{
- struct t_config_section *ptr_section;
-
secure_config_file = config_file_new (NULL, SECURE_CONFIG_PRIO_NAME,
&secure_config_reload_cb, NULL, NULL);
if (!secure_config_file)
return 0;
/* crypt */
- ptr_section = config_file_new_section (secure_config_file, "crypt",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- config_file_free (secure_config_file);
- secure_config_file = NULL;
- return 0;
- }
-
- secure_config_crypt_cipher = config_file_new_option (
- secure_config_file, ptr_section,
- "cipher", "integer",
- N_("cipher used to crypt data (the number after algorithm is the size "
- "of the key in bits)"),
- "aes128|aes192|aes256", 0, 0, "aes256", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- secure_config_crypt_hash_algo = config_file_new_option (
- secure_config_file, ptr_section,
- "hash_algo", "integer",
- N_("hash algorithm used to check the decrypted data"),
- "sha224|sha256|sha384|sha512", 0, 0, "sha256", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- secure_config_crypt_passphrase_command = config_file_new_option (
- secure_config_file, ptr_section,
- "passphrase_command", "string",
- N_("read the passphrase from the output of this system command "
- "(only the first line is used and it must not contain any extra "
- "character); this option is used only when reading file sec.conf "
- "and if the environment variable \"WEECHAT_PASSPHRASE\" is not set "
- "(the environment variable has higher priority); "
- "example with password-store: "
- "\"/usr/bin/pass show weechat/passphrase\""),
- NULL, 0, 0, "", NULL, 0,
+ secure_config_section_crypt = config_file_new_section (
+ secure_config_file, "crypt",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- secure_config_crypt_salt = config_file_new_option (
- secure_config_file, ptr_section,
- "salt", "boolean",
- N_("use salt when generating key used in encryption (recommended for "
- "maximum security); when enabled, the content of crypted data in "
- "file sec.conf will be different on each write of the file; if you "
- "put the file sec.conf in a version control system, then you "
- "can turn off this option to have always same content in file"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ if (secure_config_section_crypt)
+ {
+ secure_config_crypt_cipher = config_file_new_option (
+ secure_config_file, secure_config_section_crypt,
+ "cipher", "integer",
+ N_("cipher used to crypt data (the number after algorithm is the "
+ "size of the key in bits)"),
+ "aes128|aes192|aes256", 0, 0, "aes256", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ secure_config_crypt_hash_algo = config_file_new_option (
+ secure_config_file, secure_config_section_crypt,
+ "hash_algo", "integer",
+ N_("hash algorithm used to check the decrypted data"),
+ "sha224|sha256|sha384|sha512", 0, 0, "sha256", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ secure_config_crypt_passphrase_command = config_file_new_option (
+ secure_config_file, secure_config_section_crypt,
+ "passphrase_command", "string",
+ N_("read the passphrase from the output of this system command "
+ "(only the first line is used and it must not contain any extra "
+ "character); this option is used only when reading file "
+ "sec.conf and if the environment variable \"WEECHAT_PASSPHRASE\" "
+ "is not set (the environment variable has higher priority); "
+ "example with password-store: "
+ "\"/usr/bin/pass show weechat/passphrase\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ secure_config_crypt_salt = config_file_new_option (
+ secure_config_file, secure_config_section_crypt,
+ "salt", "boolean",
+ N_("use salt when generating key used in encryption (recommended "
+ "for maximum security); when enabled, the content of crypted "
+ "data in file sec.conf will be different on each write of the "
+ "file; if you put the file sec.conf in a version control system, "
+ "then you can turn off this option to have always same content "
+ "in file"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ }
/* data */
- ptr_section = config_file_new_section (
+ secure_config_section_data = config_file_new_section (
secure_config_file, "data",
0, 0,
&secure_config_data_read_cb, NULL, NULL,
@@ -513,12 +512,6 @@ secure_config_init_options ()
&secure_config_data_write_cb, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- config_file_free (secure_config_file);
- secure_config_file = NULL;
- return 0;
- }
return 1;
}
diff --git a/src/plugins/alias/alias-config.c b/src/plugins/alias/alias-config.c
index f6b72f4b0..7d65a1c1b 100644
--- a/src/plugins/alias/alias-config.c
+++ b/src/plugins/alias/alias-config.c
@@ -432,35 +432,31 @@ alias_config_update_cb (const void *pointer, void *data,
int
alias_config_init ()
{
- struct t_config_section *ptr_section;
-
alias_config_file = weechat_config_new (ALIAS_CONFIG_PRIO_NAME,
&alias_config_reload, NULL, NULL);
if (!alias_config_file)
return 0;
- weechat_config_set_version (alias_config_file, ALIAS_CONFIG_VERSION,
- &alias_config_update_cb, NULL, NULL);
+ if (!weechat_config_set_version (alias_config_file, ALIAS_CONFIG_VERSION,
+ &alias_config_update_cb, NULL, NULL))
+ {
+ weechat_config_free (alias_config_file);
+ alias_config_file = NULL;
+ return 0;
+ }
/* cmd */
- ptr_section = weechat_config_new_section (
+ alias_config_section_cmd = weechat_config_new_section (
alias_config_file, "cmd",
1, 1,
NULL, NULL, NULL,
NULL, NULL, NULL,
&alias_config_cmd_write_default_cb, NULL, NULL,
&alias_config_cmd_create_option_cb, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (alias_config_file);
- alias_config_file = NULL;
- return 0;
- }
- alias_config_section_cmd = ptr_section;
+ NULL, NULL, NULL);
/* completion */
- ptr_section = weechat_config_new_section (
+ alias_config_section_completion = weechat_config_new_section (
alias_config_file, "completion",
1, 1,
NULL, NULL, NULL,
@@ -468,13 +464,6 @@ alias_config_init ()
&alias_config_completion_write_default_cb, NULL, NULL,
&alias_config_completion_create_option_cb, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (alias_config_file);
- alias_config_file = NULL;
- return 0;
- }
- alias_config_section_completion = ptr_section;
return 1;
}
diff --git a/src/plugins/buflist/buflist-config.c b/src/plugins/buflist/buflist-config.c
index 2e63e934f..7a2f94a0d 100644
--- a/src/plugins/buflist/buflist-config.c
+++ b/src/plugins/buflist/buflist-config.c
@@ -31,35 +31,42 @@
struct t_config_file *buflist_config_file = NULL;
+/* sections */
+
+struct t_config_section *buflist_config_section_look = NULL;
+struct t_config_section *buflist_config_section_format = NULL;
+
/* buflist config, look section */
-struct t_config_option *buflist_config_look_add_newline;
-struct t_config_option *buflist_config_look_auto_scroll;
-struct t_config_option *buflist_config_look_display_conditions;
-struct t_config_option *buflist_config_look_enabled;
-struct t_config_option *buflist_config_look_mouse_jump_visited_buffer;
-struct t_config_option *buflist_config_look_mouse_move_buffer;
-struct t_config_option *buflist_config_look_mouse_wheel;
-struct t_config_option *buflist_config_look_nick_prefix;
-struct t_config_option *buflist_config_look_nick_prefix_empty;
-struct t_config_option *buflist_config_look_signals_refresh;
-struct t_config_option *buflist_config_look_sort;
-struct t_config_option *buflist_config_look_use_items;
+struct t_config_option *buflist_config_look_add_newline = NULL;
+struct t_config_option *buflist_config_look_auto_scroll = NULL;
+struct t_config_option *buflist_config_look_display_conditions = NULL;
+struct t_config_option *buflist_config_look_enabled = NULL;
+struct t_config_option *buflist_config_look_mouse_jump_visited_buffer = NULL;
+struct t_config_option *buflist_config_look_mouse_move_buffer = NULL;
+struct t_config_option *buflist_config_look_mouse_wheel = NULL;
+struct t_config_option *buflist_config_look_nick_prefix = NULL;
+struct t_config_option *buflist_config_look_nick_prefix_empty = NULL;
+struct t_config_option *buflist_config_look_signals_refresh = NULL;
+struct t_config_option *buflist_config_look_sort = NULL;
+struct t_config_option *buflist_config_look_use_items = NULL;
/* buflist config, format section */
-struct t_config_option *buflist_config_format_buffer;
-struct t_config_option *buflist_config_format_buffer_current;
-struct t_config_option *buflist_config_format_hotlist;
-struct t_config_option *buflist_config_format_hotlist_level[4];
-struct t_config_option *buflist_config_format_hotlist_level_none;
-struct t_config_option *buflist_config_format_hotlist_separator;
-struct t_config_option *buflist_config_format_indent;
-struct t_config_option *buflist_config_format_lag;
-struct t_config_option *buflist_config_format_name;
-struct t_config_option *buflist_config_format_nick_prefix;
-struct t_config_option *buflist_config_format_number;
-struct t_config_option *buflist_config_format_tls_version;
+struct t_config_option *buflist_config_format_buffer = NULL;
+struct t_config_option *buflist_config_format_buffer_current = NULL;
+struct t_config_option *buflist_config_format_hotlist = NULL;
+struct t_config_option *buflist_config_format_hotlist_level[4] = {
+ NULL, NULL, NULL, NULL,
+};
+struct t_config_option *buflist_config_format_hotlist_level_none = NULL;
+struct t_config_option *buflist_config_format_hotlist_separator = NULL;
+struct t_config_option *buflist_config_format_indent = NULL;
+struct t_config_option *buflist_config_format_lag = NULL;
+struct t_config_option *buflist_config_format_name = NULL;
+struct t_config_option *buflist_config_format_nick_prefix = NULL;
+struct t_config_option *buflist_config_format_number = NULL;
+struct t_config_option *buflist_config_format_tls_version = NULL;
struct t_hook **buflist_config_signals_refresh = NULL;
int buflist_config_num_signals_refresh = 0;
@@ -466,8 +473,6 @@ buflist_config_change_format (const void *pointer, void *data,
int
buflist_config_init ()
{
- struct t_config_section *ptr_section;
-
buflist_config_file = weechat_config_new (
BUFLIST_CONFIG_PRIO_NAME,
&buflist_config_reload, NULL, NULL);
@@ -475,324 +480,320 @@ buflist_config_init ()
return 0;
/* look */
- ptr_section = weechat_config_new_section (buflist_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (buflist_config_file);
- buflist_config_file = NULL;
- return 0;
- }
-
- buflist_config_look_add_newline = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "add_newline", "boolean",
- N_("add newline between the buffers displayed, so each buffer is "
- "displayed on a separate line (recommended); if disabled, newlines "
- "must be manually added in the formats with \"${\\n}\", "
- "and the mouse actions are not possible any more"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_auto_scroll = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "auto_scroll", "integer",
- N_("automatically scroll the buflist bar to always see the current "
- "buffer (this works only with a bar on the left/right position "
- "with a \"vertical\" filling); this value is the percent number "
- "of lines displayed before the current buffer when scrolling "
- "(-1 = disable scroll); for example 50 means that after a scroll, "
- "the current buffer is at the middle of bar, 0 means on top of "
- "bar, 100 means at bottom of bar"),
- NULL, -1, 100, "50", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_display_conditions = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "display_conditions", "string",
- N_("conditions to display a buffer "
- "(note: content is evaluated, see /help buflist); for example "
- "to hide server buffers if they are merged with core buffer: "
- "\"${buffer.hidden}==0 && ((${type}!=server && "
- "${buffer.full_name}!=core.weechat) || ${buffer.active}==1)\""),
- NULL, 0, 0, "${buffer.hidden}==0", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_enabled = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "enabled", "boolean",
- N_("enable buflist; it is recommended to use this option instead of "
- "just hiding the bar because it also removes some internal hooks "
- "that are not needed any more when the bar is hidden; you can "
- "also use the command \"/buflist toggle\" or use the default key "
- "alt+shift+b"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_enabled, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_mouse_jump_visited_buffer = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "mouse_jump_visited_buffer", "boolean",
- N_("if enabled, clicks with left/right buttons on the line with "
- "current buffer jump to previous/next visited buffer"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_mouse_move_buffer = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "mouse_move_buffer", "boolean",
- N_("if enabled, mouse gestures (drag & drop) move buffers in list"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_mouse_wheel = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "mouse_wheel", "boolean",
- N_("if enabled, mouse wheel up/down actions jump to previous/next "
- "buffer in list"),
- NULL, 0, 0, "on", NULL, 0,
+ buflist_config_section_look = weechat_config_new_section (
+ buflist_config_file, "look",
+ 0, 0,
NULL, NULL, NULL,
NULL, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_nick_prefix = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "nick_prefix", "boolean",
- N_("get the nick prefix and its color from nicklist so that "
- "${nick_prefix} can be used in format; this can be slow on buffers "
- "with lot of nicks in nicklist, so this option is disabled "
- "by default"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_nick_prefix, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_nick_prefix_empty = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "nick_prefix_empty", "boolean",
- N_("when the nick prefix is enabled, display a space instead if there "
- "is no nick prefix on the buffer"),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_signals_refresh = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "signals_refresh", "string",
- N_("comma-separated list of extra signals that are hooked and trigger "
- "the refresh of buffers list; this can be useful if some custom "
- "variables are used in formats and need specific refresh"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_signals_refresh, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_look_sort = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "sort", "string",
- N_("comma-separated list of fields to sort buffers; each field is "
- "a hdata variable of buffer (\"var\"), a hdata variable of "
- "IRC server (\"irc_server.var\") or a hdata variable of "
- "IRC channel (\"irc_channel.var\"); "
- "char \"-\" can be used before field to reverse order, "
- "char \"~\" can be used to do a case insensitive comparison; "
- "example: \"-~short_name\" for case insensitive and reverse "
- "sort on buffer short name "
- "(note: the content is evaluated, before being split into fields, "
- "but at that time \"bar_item\" is the only variable that can be "
- "used, to distinguish between different buflist items, for example "
- "\"${bar_item.name}\")"),
- NULL, 0, 0, "number,-active", NULL, 0,
NULL, NULL, NULL,
- &buflist_config_change_sort, NULL, NULL,
NULL, NULL, NULL);
- buflist_config_look_use_items = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "use_items", "integer",
- N_("number of buflist bar items that can be used; the item names are: "
- "\"buflist\", \"buflist2\", \"buflist3\"; be careful, using more "
- "than one bar item slows down the display of buffers list"),
- NULL, 1, BUFLIST_BAR_NUM_ITEMS, "1", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_use_items, NULL, NULL,
- NULL, NULL, NULL);
-
- /* format */
- ptr_section = weechat_config_new_section (buflist_config_file, "format",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (buflist_config_section_look)
{
- weechat_config_free (buflist_config_file);
- buflist_config_file = NULL;
- return 0;
+ buflist_config_look_add_newline = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "add_newline", "boolean",
+ N_("add newline between the buffers displayed, so each buffer is "
+ "displayed on a separate line (recommended); if disabled, "
+ "newlines must be manually added in the formats with \"${\\n}\", "
+ "and the mouse actions are not possible any more"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_auto_scroll = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "auto_scroll", "integer",
+ N_("automatically scroll the buflist bar to always see the current "
+ "buffer (this works only with a bar on the left/right position "
+ "with a \"vertical\" filling); this value is the percent number "
+ "of lines displayed before the current buffer when scrolling "
+ "(-1 = disable scroll); for example 50 means that after a scroll, "
+ "the current buffer is at the middle of bar, 0 means on top of "
+ "bar, 100 means at bottom of bar"),
+ NULL, -1, 100, "50", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_display_conditions = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "display_conditions", "string",
+ N_("conditions to display a buffer "
+ "(note: content is evaluated, see /help buflist); for example "
+ "to hide server buffers if they are merged with core buffer: "
+ "\"${buffer.hidden}==0 && ((${type}!=server && "
+ "${buffer.full_name}!=core.weechat) || ${buffer.active}==1)\""),
+ NULL, 0, 0, "${buffer.hidden}==0", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_enabled = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "enabled", "boolean",
+ N_("enable buflist; it is recommended to use this option instead of "
+ "just hiding the bar because it also removes some internal hooks "
+ "that are not needed any more when the bar is hidden; you can "
+ "also use the command \"/buflist toggle\" or use the default key "
+ "alt+shift+b"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_mouse_jump_visited_buffer = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "mouse_jump_visited_buffer", "boolean",
+ N_("if enabled, clicks with left/right buttons on the line with "
+ "current buffer jump to previous/next visited buffer"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_mouse_move_buffer = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "mouse_move_buffer", "boolean",
+ N_("if enabled, mouse gestures (drag & drop) move buffers in list"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_mouse_wheel = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "mouse_wheel", "boolean",
+ N_("if enabled, mouse wheel up/down actions jump to previous/next "
+ "buffer in list"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_nick_prefix = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "nick_prefix", "boolean",
+ N_("get the nick prefix and its color from nicklist so that "
+ "${nick_prefix} can be used in format; this can be slow on "
+ "buffers with lot of nicks in nicklist, so this option is "
+ "disabled by default"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_nick_prefix, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_nick_prefix_empty = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "nick_prefix_empty", "boolean",
+ N_("when the nick prefix is enabled, display a space instead if "
+ "there is no nick prefix on the buffer"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_signals_refresh = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "signals_refresh", "string",
+ N_("comma-separated list of extra signals that are hooked and "
+ "trigger the refresh of buffers list; this can be useful if "
+ "some custom variables are used in formats and need specific "
+ "refresh"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_signals_refresh, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_sort = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "sort", "string",
+ N_("comma-separated list of fields to sort buffers; each field is "
+ "a hdata variable of buffer (\"var\"), a hdata variable of "
+ "IRC server (\"irc_server.var\") or a hdata variable of "
+ "IRC channel (\"irc_channel.var\"); "
+ "char \"-\" can be used before field to reverse order, "
+ "char \"~\" can be used to do a case insensitive comparison; "
+ "example: \"-~short_name\" for case insensitive and reverse "
+ "sort on buffer short name "
+ "(note: the content is evaluated, before being split into "
+ "fields, but at that time \"bar_item\" is the only variable "
+ "that can be used, to distinguish between different buflist "
+ "items, for example \"${bar_item.name}\")"),
+ NULL, 0, 0, "number,-active", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_sort, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_look_use_items = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_look,
+ "use_items", "integer",
+ N_("number of buflist bar items that can be used; the item names "
+ "are: \"buflist\", \"buflist2\", \"buflist3\"; be careful, "
+ "using more than one bar item slows down the display of "
+ "buffers list"),
+ NULL, 1, BUFLIST_BAR_NUM_ITEMS, "1", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_use_items, NULL, NULL,
+ NULL, NULL, NULL);
}
- buflist_config_format_buffer = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "buffer", "string",
- N_("format of each line with a buffer "
- "(note: content is evaluated, see /help buflist); "
- "example: standard format for bar item \"buflist\" and only the "
- "buffer number between square brackets for other bar items "
- "(\"buflist2\" and \"buflist3\"): "
- "\"${if:${bar_item.name}==buflist?${format_number}${indent}"
- "${format_nick_prefix}${color_hotlist}${format_name}:"
- "[${number}]}\""),
- NULL, 0, 0,
- "${format_number}${indent}${format_nick_prefix}${color_hotlist}"
- "${format_name}",
- NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_format, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_buffer_current = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "buffer_current", "string",
- N_("format for the line with current buffer "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:,blue}${format_buffer}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_format, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist", "string",
- N_("format for hotlist "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0,
- " ${color:green}(${hotlist}${color:green})",
- NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_format, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_level[3] = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_highlight", "string",
- N_("format for a buffer with hotlist level \"highlight\" "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:magenta}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_level[0] = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_low", "string",
- N_("format for a buffer with hotlist level \"low\" "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:white}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_level[1] = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_message", "string",
- N_("format for a buffer with hotlist level \"message\" "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:brown}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_level_none = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_none", "string",
- N_("format for a buffer not in hotlist "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:default}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_level[2] = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_private", "string",
- N_("format for a buffer with hotlist level \"private\" "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:green}", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_hotlist_separator = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "hotlist_separator", "string",
- N_("separator for counts in hotlist "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color:default},", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_indent = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "indent", "string",
- N_("string displayed to indent channel and private buffers "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, " ", NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_lag = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "lag", "string",
- N_("format for lag on an IRC server buffer "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0,
- " ${color:green}[${color:brown}${lag}${color:green}]",
- NULL, 0,
- NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_name = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "name", "string",
- N_("format for buffer name "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${name}", NULL, 0,
+ /* format */
+ buflist_config_section_format = weechat_config_new_section (
+ buflist_config_file, "format",
+ 0, 0,
NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_nick_prefix = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "nick_prefix", "string",
- N_("format for nick prefix on a channel "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0, "${color_nick_prefix}${nick_prefix}", NULL, 0,
NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_number = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "number", "string",
- N_("format for buffer number, ${number} is the indented number "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0,
- "${color:green}${number}${if:${number_displayed}?.: }",
- NULL, 0,
NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
- NULL, NULL, NULL);
- buflist_config_format_tls_version = weechat_config_new_option (
- buflist_config_file, ptr_section,
- "tls_version", "string",
- N_("format for TLS version on an IRC server buffer "
- "(note: content is evaluated, see /help buflist)"),
- NULL, 0, 0,
- " ${color:default}(${if:${tls_version}==TLS1.3?${color:green}:"
- "${if:${tls_version}==TLS1.2?${color:yellow}:${color:red}}}"
- "${translate:${tls_version}}${color:default})",
- NULL, 0,
NULL, NULL, NULL,
- &buflist_config_change_buflist, NULL, NULL,
NULL, NULL, NULL);
+ if (buflist_config_section_format)
+ {
+ buflist_config_format_buffer = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "buffer", "string",
+ N_("format of each line with a buffer "
+ "(note: content is evaluated, see /help buflist); "
+ "example: standard format for bar item \"buflist\" and only the "
+ "buffer number between square brackets for other bar items "
+ "(\"buflist2\" and \"buflist3\"): "
+ "\"${if:${bar_item.name}==buflist?${format_number}${indent}"
+ "${format_nick_prefix}${color_hotlist}${format_name}:"
+ "[${number}]}\""),
+ NULL, 0, 0,
+ "${format_number}${indent}${format_nick_prefix}${color_hotlist}"
+ "${format_name}",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_format, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_buffer_current = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "buffer_current", "string",
+ N_("format for the line with current buffer "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:,blue}${format_buffer}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_format, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist", "string",
+ N_("format for hotlist "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0,
+ " ${color:green}(${hotlist}${color:green})",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_format, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_level[3] = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_highlight", "string",
+ N_("format for a buffer with hotlist level \"highlight\" "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:magenta}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_level[0] = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_low", "string",
+ N_("format for a buffer with hotlist level \"low\" "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:white}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_level[1] = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_message", "string",
+ N_("format for a buffer with hotlist level \"message\" "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:brown}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_level_none = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_none", "string",
+ N_("format for a buffer not in hotlist "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:default}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_level[2] = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_private", "string",
+ N_("format for a buffer with hotlist level \"private\" "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:green}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_hotlist_separator = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "hotlist_separator", "string",
+ N_("separator for counts in hotlist "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color:default},", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_indent = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "indent", "string",
+ N_("string displayed to indent channel and private buffers "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, " ", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_lag = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "lag", "string",
+ N_("format for lag on an IRC server buffer "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0,
+ " ${color:green}[${color:brown}${lag}${color:green}]",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_name = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "name", "string",
+ N_("format for buffer name "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${name}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_nick_prefix = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "nick_prefix", "string",
+ N_("format for nick prefix on a channel "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0, "${color_nick_prefix}${nick_prefix}", NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_number = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "number", "string",
+ N_("format for buffer number, ${number} is the indented number "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0,
+ "${color:green}${number}${if:${number_displayed}?.: }",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ buflist_config_format_tls_version = weechat_config_new_option (
+ buflist_config_file, buflist_config_section_format,
+ "tls_version", "string",
+ N_("format for TLS version on an IRC server buffer "
+ "(note: content is evaluated, see /help buflist)"),
+ NULL, 0, 0,
+ " ${color:default}(${if:${tls_version}==TLS1.3?${color:green}:"
+ "${if:${tls_version}==TLS1.2?${color:yellow}:${color:red}}}"
+ "${translate:${tls_version}}${color:default})",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &buflist_config_change_buflist, NULL, NULL,
+ NULL, NULL, NULL);
+ }
return 1;
}
diff --git a/src/plugins/exec/exec-config.c b/src/plugins/exec/exec-config.c
index 6c6ef8783..ba21ac65b 100644
--- a/src/plugins/exec/exec-config.c
+++ b/src/plugins/exec/exec-config.c
@@ -30,16 +30,21 @@
struct t_config_file *exec_config_file = NULL;
+/* sections */
+
+struct t_config_section *exec_config_section_command = NULL;
+struct t_config_section *exec_config_section_color = NULL;
+
/* exec config, command section */
-struct t_config_option *exec_config_command_default_options;
-struct t_config_option *exec_config_command_purge_delay;
-struct t_config_option *exec_config_command_shell;
+struct t_config_option *exec_config_command_default_options = NULL;
+struct t_config_option *exec_config_command_purge_delay = NULL;
+struct t_config_option *exec_config_command_shell = NULL;
/* exec config, color section */
-struct t_config_option *exec_config_color_flag_finished;
-struct t_config_option *exec_config_color_flag_running;
+struct t_config_option *exec_config_color_flag_finished = NULL;
+struct t_config_option *exec_config_color_flag_running = NULL;
char **exec_config_cmd_options = NULL;
int exec_config_cmd_num_options = 0;
@@ -98,85 +103,78 @@ exec_config_reload_cb (const void *pointer, void *data,
int
exec_config_init ()
{
- struct t_config_section *ptr_section;
-
exec_config_file = weechat_config_new (EXEC_CONFIG_PRIO_NAME,
&exec_config_reload_cb, NULL, NULL);
if (!exec_config_file)
return 0;
/* command */
- ptr_section = weechat_config_new_section (exec_config_file, "command",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ exec_config_section_command = weechat_config_new_section (
+ exec_config_file, "command",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ if (exec_config_section_command)
{
- weechat_config_free (exec_config_file);
- exec_config_file = NULL;
- return 0;
+ exec_config_command_default_options = weechat_config_new_option (
+ exec_config_file, exec_config_section_command,
+ "default_options", "string",
+ N_("default options for command /exec (see /help exec); example: "
+ "\"-nosh -bg\" to run all commands in background (no output), "
+ "and without using the shell"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &exec_config_change_command_default_options, NULL, NULL,
+ NULL, NULL, NULL);
+ exec_config_command_purge_delay = weechat_config_new_option (
+ exec_config_file, exec_config_section_command,
+ "purge_delay", "integer",
+ N_("delay for purging finished commands (in seconds, 0 = purge "
+ "commands immediately, -1 = never purge)"),
+ NULL, -1, 36000 * 24 * 30, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ exec_config_command_shell = weechat_config_new_option (
+ exec_config_file, exec_config_section_command,
+ "shell", "string",
+ N_("shell to use with command \"/exec -sh\"; it can be just the "
+ "name of shell if it is in PATH (for example \"bash\") or the "
+ "absolute path to the shell (for example \"/bin/bash\"); if "
+ "value is empty, \"sh\" is used (note: content is evaluated, "
+ "see /help eval)"),
+ NULL, 0, 0, "${env:SHELL}", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
}
- exec_config_command_default_options = weechat_config_new_option (
- exec_config_file, ptr_section,
- "default_options", "string",
- N_("default options for command /exec (see /help exec); example: "
- "\"-nosh -bg\" to run all commands in background (no output), and "
- "without using the shell"),
- NULL, 0, 0, "", NULL, 0,
+ /* color */
+ exec_config_section_color = weechat_config_new_section (
+ exec_config_file, "color",
+ 0, 0,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &exec_config_change_command_default_options, NULL, NULL,
- NULL, NULL, NULL);
- exec_config_command_purge_delay = weechat_config_new_option (
- exec_config_file, ptr_section,
- "purge_delay", "integer",
- N_("delay for purging finished commands (in seconds, 0 = purge "
- "commands immediately, -1 = never purge)"),
- NULL, -1, 36000 * 24 * 30, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- exec_config_command_shell = weechat_config_new_option (
- exec_config_file, ptr_section,
- "shell", "string",
- N_("shell to use with command \"/exec -sh\"; it can be just the name "
- "of shell if it is in PATH (for example \"bash\") or the absolute "
- "path to the shell (for example \"/bin/bash\"); if value is empty, "
- "\"sh\" is used (note: content is evaluated, see /help eval)"),
- NULL, 0, 0, "${env:SHELL}", NULL, 0,
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
-
- /* color */
- ptr_section = weechat_config_new_section (exec_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (exec_config_section_color)
{
- weechat_config_free (exec_config_file);
- exec_config_file = NULL;
- return 0;
+ exec_config_color_flag_finished = weechat_config_new_option (
+ exec_config_file, exec_config_section_color,
+ "flag_finished", "color",
+ N_("text color for a finished command flag in list of commands"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ exec_config_color_flag_running = weechat_config_new_option (
+ exec_config_file, exec_config_section_color,
+ "flag_running", "color",
+ N_("text color for a running command flag in list of commands"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- exec_config_color_flag_finished = weechat_config_new_option (
- exec_config_file, ptr_section,
- "flag_finished", "color",
- N_("text color for a finished command flag in list of commands"),
- NULL, 0, 0, "lightred", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- exec_config_color_flag_running = weechat_config_new_option (
- exec_config_file, ptr_section,
- "flag_running", "color",
- N_("text color for a running command flag in list of commands"),
- NULL, 0, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
return 1;
}
diff --git a/src/plugins/fifo/fifo-config.c b/src/plugins/fifo/fifo-config.c
index 11f03a9e9..e8dd23e9c 100644
--- a/src/plugins/fifo/fifo-config.c
+++ b/src/plugins/fifo/fifo-config.c
@@ -28,10 +28,14 @@
struct t_config_file *fifo_config_file = NULL;
+/* sections */
+
+struct t_config_section *fifo_config_section_file = NULL;
+
/* fifo config, file section */
-struct t_config_option *fifo_config_file_enabled;
-struct t_config_option *fifo_config_file_path;
+struct t_config_option *fifo_config_file_enabled = NULL;
+struct t_config_option *fifo_config_file_path = NULL;
/*
@@ -85,47 +89,42 @@ fifo_config_change_file_path (const void *pointer, void *data,
int
fifo_config_init ()
{
- struct t_config_section *ptr_section;
-
fifo_config_file = weechat_config_new (FIFO_CONFIG_PRIO_NAME,
NULL, NULL, NULL);
if (!fifo_config_file)
return 0;
/* file */
- ptr_section = weechat_config_new_section (fifo_config_file, "file",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (fifo_config_file);
- fifo_config_file = NULL;
- return 0;
- }
-
- fifo_config_file_enabled = weechat_config_new_option (
- fifo_config_file, ptr_section,
- "enabled", "boolean",
- N_("enable FIFO pipe"),
- NULL, 0, 0, "on", NULL, 0,
+ fifo_config_section_file = weechat_config_new_section (
+ fifo_config_file, "file",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &fifo_config_change_file_enabled, NULL, NULL,
- NULL, NULL, NULL);
- fifo_config_file_path = weechat_config_new_option (
- fifo_config_file, ptr_section,
- "path", "string",
- N_("path for FIFO file; "
- "WeeChat PID can be used in path with ${info:pid} "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_runtime_dir}/weechat_fifo_${info:pid}", NULL, 0,
NULL, NULL, NULL,
- fifo_config_change_file_path, NULL, NULL,
NULL, NULL, NULL);
+ if (fifo_config_section_file)
+ {
+ fifo_config_file_enabled = weechat_config_new_option (
+ fifo_config_file, fifo_config_section_file,
+ "enabled", "boolean",
+ N_("enable FIFO pipe"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &fifo_config_change_file_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ fifo_config_file_path = weechat_config_new_option (
+ fifo_config_file, fifo_config_section_file,
+ "path", "string",
+ N_("path for FIFO file; "
+ "WeeChat PID can be used in path with ${info:pid} "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_runtime_dir}/weechat_fifo_${info:pid}", NULL, 0,
+ NULL, NULL, NULL,
+ fifo_config_change_file_path, NULL, NULL,
+ NULL, NULL, NULL);
+ }
return 1;
}
diff --git a/src/plugins/fset/fset-config.c b/src/plugins/fset/fset-config.c
index 26c73c7c2..08908d0a0 100644
--- a/src/plugins/fset/fset-config.c
+++ b/src/plugins/fset/fset-config.c
@@ -32,67 +32,73 @@
struct t_config_file *fset_config_file = NULL;
+/* sections */
+
+struct t_config_section *fset_config_section_look = NULL;
+struct t_config_section *fset_config_section_format = NULL;
+struct t_config_section *fset_config_section_color = NULL;
+
/* fset config, look section */
-struct t_config_option *fset_config_look_auto_refresh;
-struct t_config_option *fset_config_look_auto_unmark;
-struct t_config_option *fset_config_look_condition_catch_set;
-struct t_config_option *fset_config_look_export_help_default;
-struct t_config_option *fset_config_look_format_number;
-struct t_config_option *fset_config_look_marked_string;
-struct t_config_option *fset_config_look_scroll_horizontal;
-struct t_config_option *fset_config_look_show_plugins_desc;
-struct t_config_option *fset_config_look_sort;
-struct t_config_option *fset_config_look_unmarked_string;
-struct t_config_option *fset_config_look_use_color_value;
-struct t_config_option *fset_config_look_use_keys;
-struct t_config_option *fset_config_look_use_mute;
+struct t_config_option *fset_config_look_auto_refresh = NULL;
+struct t_config_option *fset_config_look_auto_unmark = NULL;
+struct t_config_option *fset_config_look_condition_catch_set = NULL;
+struct t_config_option *fset_config_look_export_help_default = NULL;
+struct t_config_option *fset_config_look_format_number = NULL;
+struct t_config_option *fset_config_look_marked_string = NULL;
+struct t_config_option *fset_config_look_scroll_horizontal = NULL;
+struct t_config_option *fset_config_look_show_plugins_desc = NULL;
+struct t_config_option *fset_config_look_sort = NULL;
+struct t_config_option *fset_config_look_unmarked_string = NULL;
+struct t_config_option *fset_config_look_use_color_value = NULL;
+struct t_config_option *fset_config_look_use_keys = NULL;
+struct t_config_option *fset_config_look_use_mute = NULL;
/* fset config, format section */
-struct t_config_option *fset_config_format_export_help;
-struct t_config_option *fset_config_format_export_option;
-struct t_config_option *fset_config_format_export_option_null;
-struct t_config_option *fset_config_format_option[2];
+struct t_config_option *fset_config_format_export_help = NULL;
+struct t_config_option *fset_config_format_export_option = NULL;
+struct t_config_option *fset_config_format_export_option_null = NULL;
+struct t_config_option *fset_config_format_option[2] = { NULL, NULL };
/* fset config, color section */
-struct t_config_option *fset_config_color_default_value[2];
-struct t_config_option *fset_config_color_description[2];
-struct t_config_option *fset_config_color_file[2];
-struct t_config_option *fset_config_color_file_changed[2];
-struct t_config_option *fset_config_color_help_default_value;
-struct t_config_option *fset_config_color_help_description;
-struct t_config_option *fset_config_color_help_name;
-struct t_config_option *fset_config_color_help_quotes;
-struct t_config_option *fset_config_color_help_values;
-struct t_config_option *fset_config_color_index[2];
-struct t_config_option *fset_config_color_line_marked_bg[2];
-struct t_config_option *fset_config_color_line_selected_bg[2];
-struct t_config_option *fset_config_color_marked[2];
-struct t_config_option *fset_config_color_max[2];
-struct t_config_option *fset_config_color_min[2];
-struct t_config_option *fset_config_color_name[2];
-struct t_config_option *fset_config_color_name_changed[2];
-struct t_config_option *fset_config_color_option[2];
-struct t_config_option *fset_config_color_option_changed[2];
-struct t_config_option *fset_config_color_parent_name[2];
-struct t_config_option *fset_config_color_parent_value[2];
-struct t_config_option *fset_config_color_quotes[2];
-struct t_config_option *fset_config_color_quotes_changed[2];
-struct t_config_option *fset_config_color_section[2];
-struct t_config_option *fset_config_color_section_changed[2];
-struct t_config_option *fset_config_color_string_values[2];
-struct t_config_option *fset_config_color_title_count_options;
-struct t_config_option *fset_config_color_title_current_option;
-struct t_config_option *fset_config_color_title_filter;
-struct t_config_option *fset_config_color_title_marked_options;
-struct t_config_option *fset_config_color_title_sort;
-struct t_config_option *fset_config_color_type[2];
-struct t_config_option *fset_config_color_unmarked[2];
-struct t_config_option *fset_config_color_value[2];
-struct t_config_option *fset_config_color_value_changed[2];
-struct t_config_option *fset_config_color_value_undef[2];
+struct t_config_option *fset_config_color_default_value[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_description[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_file[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_file_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_help_default_value = NULL;
+struct t_config_option *fset_config_color_help_description = NULL;
+struct t_config_option *fset_config_color_help_name = NULL;
+struct t_config_option *fset_config_color_help_quotes = NULL;
+struct t_config_option *fset_config_color_help_values = NULL;
+struct t_config_option *fset_config_color_index[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_line_marked_bg[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_line_selected_bg[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_marked[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_max[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_min[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_name[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_name_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_option[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_option_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_parent_name[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_parent_value[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_quotes[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_quotes_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_section[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_section_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_string_values[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_title_count_options = NULL;
+struct t_config_option *fset_config_color_title_current_option = NULL;
+struct t_config_option *fset_config_color_title_filter = NULL;
+struct t_config_option *fset_config_color_title_marked_options = NULL;
+struct t_config_option *fset_config_color_title_sort = NULL;
+struct t_config_option *fset_config_color_type[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_unmarked[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_value[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_value_changed[2] = { NULL, NULL };
+struct t_config_option *fset_config_color_value_undef[2] = { NULL, NULL };
char **fset_config_auto_refresh = NULL;
char **fset_config_sort_fields = NULL;
@@ -363,755 +369,744 @@ fset_config_change_title_color_cb (const void *pointer, void *data,
int
fset_config_init ()
{
- struct t_config_section *ptr_section;
-
fset_config_file = weechat_config_new (FSET_CONFIG_PRIO_NAME,
&fset_config_reload, NULL, NULL);
if (!fset_config_file)
return 0;
/* look */
- ptr_section = weechat_config_new_section (fset_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (fset_config_file);
- fset_config_file = NULL;
- return 0;
- }
-
- fset_config_look_auto_refresh = weechat_config_new_option (
- fset_config_file, ptr_section,
- "auto_refresh", "string",
- N_("comma separated list of options to automatically refresh on the "
- "fset buffer (if opened); \"*\" means all options (recommended), "
- "a name beginning with \"!\" is a negative value to prevent an "
- "option to be refreshed, wildcard \"*\" is allowed in names "
- "(example: \"*,!plugin.section.*\")"),
- NULL, 0, 0, "*", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_auto_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_auto_unmark = weechat_config_new_option (
- fset_config_file, ptr_section,
- "auto_unmark", "boolean",
- N_("automatically unmark all options after an action on marked "
- "options or after a refresh"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_condition_catch_set = weechat_config_new_option (
- fset_config_file, ptr_section,
- "condition_catch_set", "string",
- N_("condition to catch /set command and display results in the fset "
- "buffer; following variables can be used: ${name} (name of option "
- "given for the /set command), ${count} (number of options found "
- "with the /set argument); an empty string disables the catch of "
- "/set command; with value \"1\", the fset buffer is always used "
- "with /set command"),
- NULL, 0, 0, "${count} >= 1", NULL, 0,
- NULL, NULL, NULL,
+ fset_config_section_look = weechat_config_new_section (
+ fset_config_file, "look",
+ 0, 0,
NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_export_help_default = weechat_config_new_option (
- fset_config_file, ptr_section,
- "export_help_default", "boolean",
- N_("write help for each option exported by default (this can be "
- "overridden with arguments \"-help\" and \"-nohelp\" for command "
- "/fset -export)"),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_format_number = weechat_config_new_option (
- fset_config_file, ptr_section,
- "format_number", "integer",
- N_("number of format used to display options; this is dynamically "
- "changed by the key ctrl-x on the fset buffer"),
- NULL, 1, 2, "1", NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_format_number_cb, NULL, NULL,
NULL, NULL, NULL);
- fset_config_look_marked_string = weechat_config_new_option (
- fset_config_file, ptr_section,
- "marked_string", "string",
- N_("string displayed when an option is marked (to do an action on "
- "multiple options)"),
- NULL, 0, 0, "*", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_scroll_horizontal = weechat_config_new_option (
- fset_config_file, ptr_section,
- "scroll_horizontal", "integer",
- N_("left/right scroll in fset buffer (percent of width)"),
- NULL, 1, 100, "10", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_show_plugins_desc = weechat_config_new_option (
- fset_config_file, ptr_section,
- "show_plugins_desc", "boolean",
- N_("show the plugin description options (plugins.desc.*)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_show_plugins_desc_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_sort = weechat_config_new_option (
- fset_config_file, ptr_section,
- "sort", "string",
- N_("comma-separated list of fields to sort options (see /help fset "
- "for a list of fields); char \"-\" can be used before field to "
- "reverse order, char \"~\" can be used to do a case insensitive "
- "comparison; example: \"-~name\" for case insensitive and reverse "
- "sort on option name"),
- NULL, 0, 0, "~name", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_sort_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_unmarked_string = weechat_config_new_option (
- fset_config_file, ptr_section,
- "unmarked_string", "string",
- N_("string displayed when an option is not marked"),
- NULL, 0, 0, " ", NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_use_color_value = weechat_config_new_option (
- fset_config_file, ptr_section,
- "use_color_value", "boolean",
- N_("use the color to display value of color options"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_use_color_value_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_use_keys = weechat_config_new_option (
- fset_config_file, ptr_section,
- "use_keys", "boolean",
- N_("use keys alt+X in fset buffer to do actions on options; "
- "if disabled, only the input is allowed"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_use_keys_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_look_use_mute = weechat_config_new_option (
- fset_config_file, ptr_section,
- "use_mute", "boolean",
- N_("use /mute command to set options"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_use_keys_cb, NULL, NULL,
- NULL, NULL, NULL);
-
- /* format */
- ptr_section = weechat_config_new_section (fset_config_file, "format",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (fset_config_section_look)
{
- weechat_config_free (fset_config_file);
- fset_config_file = NULL;
- return 0;
+ fset_config_look_auto_refresh = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "auto_refresh", "string",
+ N_("comma separated list of options to automatically refresh on the "
+ "fset buffer (if opened); \"*\" means all options (recommended), "
+ "a name beginning with \"!\" is a negative value to prevent an "
+ "option to be refreshed, wildcard \"*\" is allowed in names "
+ "(example: \"*,!plugin.section.*\")"),
+ NULL, 0, 0, "*", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_auto_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_auto_unmark = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "auto_unmark", "boolean",
+ N_("automatically unmark all options after an action on marked "
+ "options or after a refresh"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_condition_catch_set = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "condition_catch_set", "string",
+ N_("condition to catch /set command and display results in the fset "
+ "buffer; following variables can be used: ${name} (name of option "
+ "given for the /set command), ${count} (number of options found "
+ "with the /set argument); an empty string disables the catch of "
+ "/set command; with value \"1\", the fset buffer is always used "
+ "with /set command"),
+ NULL, 0, 0, "${count} >= 1", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_export_help_default = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "export_help_default", "boolean",
+ N_("write help for each option exported by default (this can be "
+ "overridden with arguments \"-help\" and \"-nohelp\" for command "
+ "/fset -export)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_format_number = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "format_number", "integer",
+ N_("number of format used to display options; this is dynamically "
+ "changed by the key ctrl-x on the fset buffer"),
+ NULL, 1, 2, "1", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_format_number_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_marked_string = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "marked_string", "string",
+ N_("string displayed when an option is marked (to do an action on "
+ "multiple options)"),
+ NULL, 0, 0, "*", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_scroll_horizontal = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "scroll_horizontal", "integer",
+ N_("left/right scroll in fset buffer (percent of width)"),
+ NULL, 1, 100, "10", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_show_plugins_desc = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "show_plugins_desc", "boolean",
+ N_("show the plugin description options (plugins.desc.*)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_show_plugins_desc_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_sort = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "sort", "string",
+ N_("comma-separated list of fields to sort options (see /help fset "
+ "for a list of fields); char \"-\" can be used before field to "
+ "reverse order, char \"~\" can be used to do a case insensitive "
+ "comparison; example: \"-~name\" for case insensitive and "
+ "reverse sort on option name"),
+ NULL, 0, 0, "~name", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_sort_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_unmarked_string = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "unmarked_string", "string",
+ N_("string displayed when an option is not marked"),
+ NULL, 0, 0, " ", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_use_color_value = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "use_color_value", "boolean",
+ N_("use the color to display value of color options"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_use_color_value_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_use_keys = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "use_keys", "boolean",
+ N_("use keys alt+X in fset buffer to do actions on options; "
+ "if disabled, only the input is allowed"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_use_keys_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_look_use_mute = weechat_config_new_option (
+ fset_config_file, fset_config_section_look,
+ "use_mute", "boolean",
+ N_("use /mute command to set options"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_use_keys_cb, NULL, NULL,
+ NULL, NULL, NULL);
}
- fset_config_format_export_help = weechat_config_new_option (
- fset_config_file, ptr_section,
- "export_help", "string",
- N_("format of help line written before each option exported in a file "
- "(note: content is evaluated, see /help fset)"),
- NULL, 0, 0,
- "# ${description2}",
- NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_format_export_option = weechat_config_new_option (
- fset_config_file, ptr_section,
- "export_option", "string",
- N_("format of each option exported in a file "
- "(note: content is evaluated, see /help fset)"),
- NULL, 0, 0,
- "/set ${name} ${quoted_value}",
- NULL, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_format_export_option_null = weechat_config_new_option (
- fset_config_file, ptr_section,
- "export_option_null", "string",
- N_("format of each option with \"null\" value exported in a file "
- "(note: content is evaluated, see /help fset)"),
- NULL, 0, 0,
- "/unset ${name}",
- NULL, 0,
+ /* format */
+ fset_config_section_format = weechat_config_new_section (
+ fset_config_file, "format",
+ 0, 0,
NULL, NULL, NULL,
NULL, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_format_option[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option1", "string",
- N_("first format of each line, used when option "
- "fset.look.format_number is set to 1 "
- "(note: content is evaluated, see /help fset); "
- "an empty string uses the default format "
- "(\"${marked} ${name} ${type} ${value2}\"), which is without "
- "evaluation of string and then much faster; "
- "formats can be switched with key ctrl-x"),
- NULL, 0, 0,
- "",
- NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_format_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_format_option[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option2", "string",
- N_("second format of each line, used when option "
- "fset.look.format_number is set to 2 "
- "(note: content is evaluated, see /help fset); "
- "an empty string uses the default format "
- "(\"${marked} ${name} ${type} ${value2}\"), which is without "
- "evaluation of string and then much faster; "
- "formats can be switched with key ctrl-x"),
- NULL, 0, 0,
- "${marked} ${name} ${type} ${value2}${newline}"
- " ${empty_name} ${_default_value}${color:darkgray} -- "
- "${min}..${max}${newline}"
- " ${empty_name} ${description}",
- NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_format_cb, NULL, NULL,
NULL, NULL, NULL);
-
- /* color */
- ptr_section = weechat_config_new_section (fset_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (fset_config_section_format)
{
- weechat_config_free (fset_config_file);
- fset_config_file = NULL;
- return 0;
+ fset_config_format_export_help = weechat_config_new_option (
+ fset_config_file, fset_config_section_format,
+ "export_help", "string",
+ N_("format of help line written before each option exported in a "
+ "file (note: content is evaluated, see /help fset)"),
+ NULL, 0, 0,
+ "# ${description2}",
+ NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_format_export_option = weechat_config_new_option (
+ fset_config_file, fset_config_section_format,
+ "export_option", "string",
+ N_("format of each option exported in a file "
+ "(note: content is evaluated, see /help fset)"),
+ NULL, 0, 0,
+ "/set ${name} ${quoted_value}",
+ NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_format_export_option_null = weechat_config_new_option (
+ fset_config_file, fset_config_section_format,
+ "export_option_null", "string",
+ N_("format of each option with \"null\" value exported in a file "
+ "(note: content is evaluated, see /help fset)"),
+ NULL, 0, 0,
+ "/unset ${name}",
+ NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_format_option[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_format,
+ "option1", "string",
+ N_("first format of each line, used when option "
+ "fset.look.format_number is set to 1 "
+ "(note: content is evaluated, see /help fset); "
+ "an empty string uses the default format "
+ "(\"${marked} ${name} ${type} ${value2}\"), which is without "
+ "evaluation of string and then much faster; "
+ "formats can be switched with key ctrl-x"),
+ NULL, 0, 0,
+ "",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_format_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_format_option[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_format,
+ "option2", "string",
+ N_("second format of each line, used when option "
+ "fset.look.format_number is set to 2 "
+ "(note: content is evaluated, see /help fset); "
+ "an empty string uses the default format "
+ "(\"${marked} ${name} ${type} ${value2}\"), which is without "
+ "evaluation of string and then much faster; "
+ "formats can be switched with key ctrl-x"),
+ NULL, 0, 0,
+ "${marked} ${name} ${type} ${value2}${newline}"
+ " ${empty_name} ${_default_value}${color:darkgray} -- "
+ "${min}..${max}${newline}"
+ " ${empty_name} ${description}",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_format_cb, NULL, NULL,
+ NULL, NULL, NULL);
}
- fset_config_color_default_value[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "default_value", "color",
- N_("color for default value"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_default_value[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "default_value_selected", "color",
- N_("color for default value on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_description[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "description", "color",
- N_("color for description"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_description[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "description_selected", "color",
- N_("color for description on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_file[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "file", "color",
- N_("color for file"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_file_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "file_changed", "color",
- N_("color for file if value is changed"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_file_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "file_changed_selected", "color",
- N_("color for file if value is changed on the selected line"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_file[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "file_selected", "color",
- N_("color for file on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_help_default_value = weechat_config_new_option (
- fset_config_file, ptr_section,
- "help_default_value", "color",
- N_("color for default value in help bar"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_help_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_help_description = weechat_config_new_option (
- fset_config_file, ptr_section,
- "help_description", "color",
- N_("color for description in help bar"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_help_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_help_name = weechat_config_new_option (
- fset_config_file, ptr_section,
- "help_name", "color",
- N_("color for name in help bar"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_help_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_help_quotes = weechat_config_new_option (
- fset_config_file, ptr_section,
- "help_quotes", "color",
- N_("color for quotes around string values"),
- NULL, 0, 0, "darkgray", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_help_values = weechat_config_new_option (
- fset_config_file, ptr_section,
- "help_values", "color",
- N_("color for allowed values"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_index[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "index", "color",
- N_("color for index of option"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_index[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "index_selected", "color",
- N_("color for index of option on the selected line"),
- NULL, 0, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_line_marked_bg[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "line_marked_bg1", "color",
- N_("background color for a marked line "
- "(used with the first format, see option fset.format.option1)"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_line_marked_bg[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "line_marked_bg2", "color",
- N_("background color for a marked line "
- "(used with the second format, see option fset.format.option2)"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_line_selected_bg[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "line_selected_bg1", "color",
- N_("background color for the selected line "
- "(used with the first format, see option fset.format.option1)"),
- NULL, 0, 0, "blue", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_line_selected_bg[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "line_selected_bg2", "color",
- N_("background color for the selected line "
- "(used with the second format, see option fset.format.option2)"),
- NULL, 0, 0, "red", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_marked[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "marked", "color",
- N_("color for mark indicator"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_marked[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "marked_selected", "color",
- N_("color for mark indicator on the selected line"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_max[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "max", "color",
- N_("color for max value"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_max[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "max_selected", "color",
- N_("color for max value on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_min[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "min", "color",
- N_("color for min value"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_min[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "min_selected", "color",
- N_("color for min value on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_name[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "name", "color",
- N_("color for name"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_name_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "name_changed", "color",
- N_("color for name if value is changed"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_name_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "name_changed_selected", "color",
- N_("color for name if value is changed on the selected line"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_name[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "name_selected", "color",
- N_("color for name on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_option[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option", "color",
- N_("color for option"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_option_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option_changed", "color",
- N_("color for option if value is changed"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_option_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option_changed_selected", "color",
- N_("color for option if value is changed on the selected line"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_option[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "option_selected", "color",
- N_("color for option on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_parent_name[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "parent_name", "color",
- N_("color for name of parent option"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_parent_name[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "parent_name_selected", "color",
- N_("color for name of parent option on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_parent_value[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "parent_value", "color",
- N_("color for value of parent option"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_parent_value[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "parent_value_selected", "color",
- N_("color for value of parent option on the selected line"),
- NULL, 0, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_quotes[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "quotes", "color",
- N_("color for quotes around string values"),
- NULL, 0, 0, "darkgray", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_quotes_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "quotes_changed", "color",
- N_("color for quotes around string values which are changed"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_quotes_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "quotes_changed_selected", "color",
- N_("color for quotes around string values which are changed "
- "on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_quotes[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "quotes_selected", "color",
- N_("color for quotes around string values on the selected line"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_section[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "section", "color",
- N_("color for section"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_section_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "section_changed", "color",
- N_("color for section if value is changed"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_section_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "section_changed_selected", "color",
- N_("color for section if value is changed on the selected line"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_section[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "section_selected", "color",
- N_("color for section on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_string_values[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "string_values", "color",
- N_("color for string values"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_string_values[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "string_values_selected", "color",
- N_("color for string values on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_title_count_options = weechat_config_new_option (
- fset_config_file, ptr_section,
- "title_count_options", "color",
- N_("color for the count of options found with the current filter "
- "in title of buffer"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_title_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_title_current_option = weechat_config_new_option (
- fset_config_file, ptr_section,
- "title_current_option", "color",
- N_("color for current option number in title of buffer"),
- NULL, 0, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_title_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_title_filter = weechat_config_new_option (
- fset_config_file, ptr_section,
- "title_filter", "color",
- N_("color for filter in title of buffer"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_title_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_title_marked_options = weechat_config_new_option (
- fset_config_file, ptr_section,
- "title_marked_options", "color",
- N_("color for number of marked options in title of buffer"),
- NULL, 0, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_title_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_title_sort = weechat_config_new_option (
- fset_config_file, ptr_section,
- "title_sort", "color",
- N_("color for sort in title of buffer"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_title_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_type[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "type", "color",
- N_("color for type"),
- NULL, 0, 0, "green", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_type[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "type_selected", "color",
- N_("color for type on the selected line"),
- NULL, 0, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_unmarked[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "unmarked", "color",
- N_("color for mark indicator when the option is not marked"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_unmarked[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "unmarked_selected", "color",
- N_("color for mark indicator when the option is not marked "
- "on the selected line"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value", "color",
- N_("color for value"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value_changed[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value_changed", "color",
- N_("color for value changed (different from default)"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value_changed[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value_changed_selected", "color",
- N_("color for value changed (different from default) on the selected "
- "line"),
- NULL, 0, 0, "yellow", NULL, 0,
+ /* color */
+ fset_config_section_color = weechat_config_new_section (
+ fset_config_file, "color",
+ 0, 0,
NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value_selected", "color",
- N_("color for value on the selected line"),
- NULL, 0, 0, "lightcyan", NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value_undef[0] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value_undef", "color",
- N_("color for undefined value"),
- NULL, 0, 0, "magenta", NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
- NULL, NULL, NULL);
- fset_config_color_value_undef[1] = weechat_config_new_option (
- fset_config_file, ptr_section,
- "value_undef_selected", "color",
- N_("color for undefined value on the selected line"),
- NULL, 0, 0, "lightmagenta", NULL, 0,
NULL, NULL, NULL,
- &fset_config_change_color_cb, NULL, NULL,
NULL, NULL, NULL);
+ if (fset_config_section_color)
+ {
+ fset_config_color_default_value[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "default_value", "color",
+ N_("color for default value"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_default_value[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "default_value_selected", "color",
+ N_("color for default value on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_description[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "description", "color",
+ N_("color for description"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_description[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "description_selected", "color",
+ N_("color for description on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_file[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "file", "color",
+ N_("color for file"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_file_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "file_changed", "color",
+ N_("color for file if value is changed"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_file_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "file_changed_selected", "color",
+ N_("color for file if value is changed on the selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_file[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "file_selected", "color",
+ N_("color for file on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_help_default_value = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "help_default_value", "color",
+ N_("color for default value in help bar"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_help_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_help_description = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "help_description", "color",
+ N_("color for description in help bar"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_help_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_help_name = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "help_name", "color",
+ N_("color for name in help bar"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_help_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_help_quotes = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "help_quotes", "color",
+ N_("color for quotes around string values"),
+ NULL, 0, 0, "darkgray", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_help_values = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "help_values", "color",
+ N_("color for allowed values"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_index[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "index", "color",
+ N_("color for index of option"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_index[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "index_selected", "color",
+ N_("color for index of option on the selected line"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_line_marked_bg[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "line_marked_bg1", "color",
+ N_("background color for a marked line "
+ "(used with the first format, see option fset.format.option1)"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_line_marked_bg[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "line_marked_bg2", "color",
+ N_("background color for a marked line "
+ "(used with the second format, see option fset.format.option2)"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_line_selected_bg[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "line_selected_bg1", "color",
+ N_("background color for the selected line "
+ "(used with the first format, see option fset.format.option1)"),
+ NULL, 0, 0, "blue", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_line_selected_bg[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "line_selected_bg2", "color",
+ N_("background color for the selected line "
+ "(used with the second format, see option fset.format.option2)"),
+ NULL, 0, 0, "red", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_marked[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "marked", "color",
+ N_("color for mark indicator"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_marked[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "marked_selected", "color",
+ N_("color for mark indicator on the selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_max[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "max", "color",
+ N_("color for max value"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_max[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "max_selected", "color",
+ N_("color for max value on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_min[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "min", "color",
+ N_("color for min value"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_min[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "min_selected", "color",
+ N_("color for min value on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_name[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "name", "color",
+ N_("color for name"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_name_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "name_changed", "color",
+ N_("color for name if value is changed"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_name_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "name_changed_selected", "color",
+ N_("color for name if value is changed on the selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_name[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "name_selected", "color",
+ N_("color for name on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_option[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "option", "color",
+ N_("color for option"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_option_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "option_changed", "color",
+ N_("color for option if value is changed"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_option_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "option_changed_selected", "color",
+ N_("color for option if value is changed on the selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_option[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "option_selected", "color",
+ N_("color for option on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_parent_name[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "parent_name", "color",
+ N_("color for name of parent option"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_parent_name[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "parent_name_selected", "color",
+ N_("color for name of parent option on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_parent_value[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "parent_value", "color",
+ N_("color for value of parent option"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_parent_value[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "parent_value_selected", "color",
+ N_("color for value of parent option on the selected line"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_quotes[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "quotes", "color",
+ N_("color for quotes around string values"),
+ NULL, 0, 0, "darkgray", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_quotes_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "quotes_changed", "color",
+ N_("color for quotes around string values which are changed"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_quotes_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "quotes_changed_selected", "color",
+ N_("color for quotes around string values which are changed "
+ "on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_quotes[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "quotes_selected", "color",
+ N_("color for quotes around string values on the selected line"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_section[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "section", "color",
+ N_("color for section"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_section_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "section_changed", "color",
+ N_("color for section if value is changed"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_section_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "section_changed_selected", "color",
+ N_("color for section if value is changed on the selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_section[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "section_selected", "color",
+ N_("color for section on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_string_values[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "string_values", "color",
+ N_("color for string values"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_string_values[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "string_values_selected", "color",
+ N_("color for string values on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_title_count_options = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "title_count_options", "color",
+ N_("color for the count of options found with the current filter "
+ "in title of buffer"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_title_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_title_current_option = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "title_current_option", "color",
+ N_("color for current option number in title of buffer"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_title_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_title_filter = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "title_filter", "color",
+ N_("color for filter in title of buffer"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_title_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_title_marked_options = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "title_marked_options", "color",
+ N_("color for number of marked options in title of buffer"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_title_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_title_sort = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "title_sort", "color",
+ N_("color for sort in title of buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_title_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_type[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "type", "color",
+ N_("color for type"),
+ NULL, 0, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_type[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "type_selected", "color",
+ N_("color for type on the selected line"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_unmarked[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "unmarked", "color",
+ N_("color for mark indicator when the option is not marked"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_unmarked[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "unmarked_selected", "color",
+ N_("color for mark indicator when the option is not marked "
+ "on the selected line"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value", "color",
+ N_("color for value"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value_changed[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value_changed", "color",
+ N_("color for value changed (different from default)"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value_changed[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value_changed_selected", "color",
+ N_("color for value changed (different from default) on the "
+ "selected line"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value_selected", "color",
+ N_("color for value on the selected line"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value_undef[0] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value_undef", "color",
+ N_("color for undefined value"),
+ NULL, 0, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ fset_config_color_value_undef[1] = weechat_config_new_option (
+ fset_config_file, fset_config_section_color,
+ "value_undef_selected", "color",
+ N_("color for undefined value on the selected line"),
+ NULL, 0, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &fset_config_change_color_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ }
return 1;
}
diff --git a/src/plugins/irc/irc-config.c b/src/plugins/irc/irc-config.c
index 57304bf38..bc243b15f 100644
--- a/src/plugins/irc/irc-config.c
+++ b/src/plugins/irc/irc-config.c
@@ -42,8 +42,15 @@
struct t_config_file *irc_config_file = NULL;
+
+/* sections */
+
+struct t_config_section *irc_config_section_look = NULL;
+struct t_config_section *irc_config_section_color = NULL;
+struct t_config_section *irc_config_section_network = NULL;
struct t_config_section *irc_config_section_msgbuffer = NULL;
struct t_config_section *irc_config_section_ctcp = NULL;
+struct t_config_section *irc_config_section_ignore = NULL;
struct t_config_section *irc_config_section_server_default = NULL;
struct t_config_section *irc_config_section_server = NULL;
@@ -51,119 +58,122 @@ int irc_config_loading = 0;
/* IRC config, look section */
-struct t_config_option *irc_config_look_buffer_open_before_autojoin;
-struct t_config_option *irc_config_look_buffer_open_before_join;
-struct t_config_option *irc_config_look_buffer_switch_autojoin;
-struct t_config_option *irc_config_look_buffer_switch_join;
-struct t_config_option *irc_config_look_color_nicks_in_names;
-struct t_config_option *irc_config_look_color_nicks_in_nicklist;
-struct t_config_option *irc_config_look_color_nicks_in_server_messages;
-struct t_config_option *irc_config_look_color_pv_nick_like_channel;
-struct t_config_option *irc_config_look_ctcp_time_format;
-struct t_config_option *irc_config_look_display_account_message;
-struct t_config_option *irc_config_look_display_away;
-struct t_config_option *irc_config_look_display_ctcp_blocked;
-struct t_config_option *irc_config_look_display_ctcp_reply;
-struct t_config_option *irc_config_look_display_ctcp_unknown;
-struct t_config_option *irc_config_look_display_extended_join;
-struct t_config_option *irc_config_look_display_host_join;
-struct t_config_option *irc_config_look_display_host_join_local;
-struct t_config_option *irc_config_look_display_host_quit;
-struct t_config_option *irc_config_look_display_join_message;
-struct t_config_option *irc_config_look_display_old_topic;
-struct t_config_option *irc_config_look_display_pv_away_once;
-struct t_config_option *irc_config_look_display_pv_back;
-struct t_config_option *irc_config_look_display_pv_nick_change;
-struct t_config_option *irc_config_look_display_pv_warning_address;
-struct t_config_option *irc_config_look_highlight_channel;
-struct t_config_option *irc_config_look_highlight_pv;
-struct t_config_option *irc_config_look_highlight_server;
-struct t_config_option *irc_config_look_highlight_tags_restrict;
-struct t_config_option *irc_config_look_item_channel_modes_hide_args;
-struct t_config_option *irc_config_look_item_display_server;
-struct t_config_option *irc_config_look_item_nick_modes;
-struct t_config_option *irc_config_look_item_nick_prefix;
-struct t_config_option *irc_config_look_join_auto_add_chantype;
-struct t_config_option *irc_config_look_msgbuffer_fallback;
-struct t_config_option *irc_config_look_new_channel_position;
-struct t_config_option *irc_config_look_new_pv_position;
-struct t_config_option *irc_config_look_nick_completion_smart;
-struct t_config_option *irc_config_look_nick_mode;
-struct t_config_option *irc_config_look_nick_mode_empty;
-struct t_config_option *irc_config_look_nicks_hide_password;
-struct t_config_option *irc_config_look_notice_as_pv;
-struct t_config_option *irc_config_look_notice_welcome_redirect;
-struct t_config_option *irc_config_look_notice_welcome_tags;
-struct t_config_option *irc_config_look_notify_tags_ison;
-struct t_config_option *irc_config_look_notify_tags_whois;
-struct t_config_option *irc_config_look_part_closes_buffer;
-struct t_config_option *irc_config_look_pv_buffer;
-struct t_config_option *irc_config_look_pv_tags;
-struct t_config_option *irc_config_look_raw_messages;
-struct t_config_option *irc_config_look_typing_status_nicks;
-struct t_config_option *irc_config_look_typing_status_self;
-struct t_config_option *irc_config_look_server_buffer;
-struct t_config_option *irc_config_look_smart_filter;
-struct t_config_option *irc_config_look_smart_filter_account;
-struct t_config_option *irc_config_look_smart_filter_chghost;
-struct t_config_option *irc_config_look_smart_filter_delay;
-struct t_config_option *irc_config_look_smart_filter_join;
-struct t_config_option *irc_config_look_smart_filter_join_unmask;
-struct t_config_option *irc_config_look_smart_filter_mode;
-struct t_config_option *irc_config_look_smart_filter_nick;
-struct t_config_option *irc_config_look_smart_filter_quit;
-struct t_config_option *irc_config_look_smart_filter_setname;
-struct t_config_option *irc_config_look_temporary_servers;
-struct t_config_option *irc_config_look_topic_strip_colors;
+struct t_config_option *irc_config_look_buffer_open_before_autojoin = NULL;
+struct t_config_option *irc_config_look_buffer_open_before_join = NULL;
+struct t_config_option *irc_config_look_buffer_switch_autojoin = NULL;
+struct t_config_option *irc_config_look_buffer_switch_join = NULL;
+struct t_config_option *irc_config_look_color_nicks_in_names = NULL;
+struct t_config_option *irc_config_look_color_nicks_in_nicklist = NULL;
+struct t_config_option *irc_config_look_color_nicks_in_server_messages = NULL;
+struct t_config_option *irc_config_look_color_pv_nick_like_channel = NULL;
+struct t_config_option *irc_config_look_ctcp_time_format = NULL;
+struct t_config_option *irc_config_look_display_account_message = NULL;
+struct t_config_option *irc_config_look_display_away = NULL;
+struct t_config_option *irc_config_look_display_ctcp_blocked = NULL;
+struct t_config_option *irc_config_look_display_ctcp_reply = NULL;
+struct t_config_option *irc_config_look_display_ctcp_unknown = NULL;
+struct t_config_option *irc_config_look_display_extended_join = NULL;
+struct t_config_option *irc_config_look_display_host_join = NULL;
+struct t_config_option *irc_config_look_display_host_join_local = NULL;
+struct t_config_option *irc_config_look_display_host_quit = NULL;
+struct t_config_option *irc_config_look_display_join_message = NULL;
+struct t_config_option *irc_config_look_display_old_topic = NULL;
+struct t_config_option *irc_config_look_display_pv_away_once = NULL;
+struct t_config_option *irc_config_look_display_pv_back = NULL;
+struct t_config_option *irc_config_look_display_pv_nick_change = NULL;
+struct t_config_option *irc_config_look_display_pv_warning_address = NULL;
+struct t_config_option *irc_config_look_highlight_channel = NULL;
+struct t_config_option *irc_config_look_highlight_pv = NULL;
+struct t_config_option *irc_config_look_highlight_server = NULL;
+struct t_config_option *irc_config_look_highlight_tags_restrict = NULL;
+struct t_config_option *irc_config_look_item_channel_modes_hide_args = NULL;
+struct t_config_option *irc_config_look_item_display_server = NULL;
+struct t_config_option *irc_config_look_item_nick_modes = NULL;
+struct t_config_option *irc_config_look_item_nick_prefix = NULL;
+struct t_config_option *irc_config_look_join_auto_add_chantype = NULL;
+struct t_config_option *irc_config_look_msgbuffer_fallback = NULL;
+struct t_config_option *irc_config_look_new_channel_position = NULL;
+struct t_config_option *irc_config_look_new_pv_position = NULL;
+struct t_config_option *irc_config_look_nick_completion_smart = NULL;
+struct t_config_option *irc_config_look_nick_mode = NULL;
+struct t_config_option *irc_config_look_nick_mode_empty = NULL;
+struct t_config_option *irc_config_look_nicks_hide_password = NULL;
+struct t_config_option *irc_config_look_notice_as_pv = NULL;
+struct t_config_option *irc_config_look_notice_welcome_redirect = NULL;
+struct t_config_option *irc_config_look_notice_welcome_tags = NULL;
+struct t_config_option *irc_config_look_notify_tags_ison = NULL;
+struct t_config_option *irc_config_look_notify_tags_whois = NULL;
+struct t_config_option *irc_config_look_part_closes_buffer = NULL;
+struct t_config_option *irc_config_look_pv_buffer = NULL;
+struct t_config_option *irc_config_look_pv_tags = NULL;
+struct t_config_option *irc_config_look_raw_messages = NULL;
+struct t_config_option *irc_config_look_typing_status_nicks = NULL;
+struct t_config_option *irc_config_look_typing_status_self = NULL;
+struct t_config_option *irc_config_look_server_buffer = NULL;
+struct t_config_option *irc_config_look_smart_filter = NULL;
+struct t_config_option *irc_config_look_smart_filter_account = NULL;
+struct t_config_option *irc_config_look_smart_filter_chghost = NULL;
+struct t_config_option *irc_config_look_smart_filter_delay = NULL;
+struct t_config_option *irc_config_look_smart_filter_join = NULL;
+struct t_config_option *irc_config_look_smart_filter_join_unmask = NULL;
+struct t_config_option *irc_config_look_smart_filter_mode = NULL;
+struct t_config_option *irc_config_look_smart_filter_nick = NULL;
+struct t_config_option *irc_config_look_smart_filter_quit = NULL;
+struct t_config_option *irc_config_look_smart_filter_setname = NULL;
+struct t_config_option *irc_config_look_temporary_servers = NULL;
+struct t_config_option *irc_config_look_topic_strip_colors = NULL;
/* IRC config, color section */
-struct t_config_option *irc_config_color_input_nick;
-struct t_config_option *irc_config_color_item_channel_modes;
-struct t_config_option *irc_config_color_item_lag_counting;
-struct t_config_option *irc_config_color_item_lag_finished;
-struct t_config_option *irc_config_color_item_nick_modes;
-struct t_config_option *irc_config_color_item_tls_version_deprecated;
-struct t_config_option *irc_config_color_item_tls_version_insecure;
-struct t_config_option *irc_config_color_item_tls_version_ok;
-struct t_config_option *irc_config_color_message_account;
-struct t_config_option *irc_config_color_message_join;
-struct t_config_option *irc_config_color_message_chghost;
-struct t_config_option *irc_config_color_message_join;
-struct t_config_option *irc_config_color_message_kick;
-struct t_config_option *irc_config_color_message_quit;
-struct t_config_option *irc_config_color_message_setname;
-struct t_config_option *irc_config_color_mirc_remap;
-struct t_config_option *irc_config_color_nick_prefixes;
-struct t_config_option *irc_config_color_notice;
-struct t_config_option *irc_config_color_reason_kick;
-struct t_config_option *irc_config_color_reason_quit;
-struct t_config_option *irc_config_color_topic_current;
-struct t_config_option *irc_config_color_topic_new;
-struct t_config_option *irc_config_color_topic_old;
+struct t_config_option *irc_config_color_input_nick = NULL;
+struct t_config_option *irc_config_color_item_channel_modes = NULL;
+struct t_config_option *irc_config_color_item_lag_counting = NULL;
+struct t_config_option *irc_config_color_item_lag_finished = NULL;
+struct t_config_option *irc_config_color_item_nick_modes = NULL;
+struct t_config_option *irc_config_color_item_tls_version_deprecated = NULL;
+struct t_config_option *irc_config_color_item_tls_version_insecure = NULL;
+struct t_config_option *irc_config_color_item_tls_version_ok = NULL;
+struct t_config_option *irc_config_color_message_account = NULL;
+struct t_config_option *irc_config_color_message_chghost = NULL;
+struct t_config_option *irc_config_color_message_join = NULL;
+struct t_config_option *irc_config_color_message_kick = NULL;
+struct t_config_option *irc_config_color_message_quit = NULL;
+struct t_config_option *irc_config_color_message_setname = NULL;
+struct t_config_option *irc_config_color_mirc_remap = NULL;
+struct t_config_option *irc_config_color_nick_prefixes = NULL;
+struct t_config_option *irc_config_color_notice = NULL;
+struct t_config_option *irc_config_color_reason_kick = NULL;
+struct t_config_option *irc_config_color_reason_quit = NULL;
+struct t_config_option *irc_config_color_topic_current = NULL;
+struct t_config_option *irc_config_color_topic_new = NULL;
+struct t_config_option *irc_config_color_topic_old = NULL;
/* IRC config, network section */
-struct t_config_option *irc_config_network_autoreconnect_delay_growing;
-struct t_config_option *irc_config_network_autoreconnect_delay_max;
-struct t_config_option *irc_config_network_ban_mask_default;
-struct t_config_option *irc_config_network_colors_receive;
-struct t_config_option *irc_config_network_colors_send;
-struct t_config_option *irc_config_network_lag_check;
-struct t_config_option *irc_config_network_lag_max;
-struct t_config_option *irc_config_network_lag_min_show;
-struct t_config_option *irc_config_network_lag_reconnect;
-struct t_config_option *irc_config_network_lag_refresh_interval;
-struct t_config_option *irc_config_network_notify_check_ison;
-struct t_config_option *irc_config_network_notify_check_whois;
-struct t_config_option *irc_config_network_sasl_fail_unavailable;
-struct t_config_option *irc_config_network_send_unknown_commands;
-struct t_config_option *irc_config_network_whois_double_nick;
+struct t_config_option *irc_config_network_autoreconnect_delay_growing = NULL;
+struct t_config_option *irc_config_network_autoreconnect_delay_max = NULL;
+struct t_config_option *irc_config_network_ban_mask_default = NULL;
+struct t_config_option *irc_config_network_colors_receive = NULL;
+struct t_config_option *irc_config_network_colors_send = NULL;
+struct t_config_option *irc_config_network_lag_check = NULL;
+struct t_config_option *irc_config_network_lag_max = NULL;
+struct t_config_option *irc_config_network_lag_min_show = NULL;
+struct t_config_option *irc_config_network_lag_reconnect = NULL;
+struct t_config_option *irc_config_network_lag_refresh_interval = NULL;
+struct t_config_option *irc_config_network_notify_check_ison = NULL;
+struct t_config_option *irc_config_network_notify_check_whois = NULL;
+struct t_config_option *irc_config_network_sasl_fail_unavailable = NULL;
+struct t_config_option *irc_config_network_send_unknown_commands = NULL;
+struct t_config_option *irc_config_network_whois_double_nick = NULL;
/* IRC config, server section */
-struct t_config_option *irc_config_server_default[IRC_SERVER_NUM_OPTIONS];
-
+struct t_config_option *irc_config_server_default[IRC_SERVER_NUM_OPTIONS] = {
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+};
struct t_hook *irc_config_hook_config_nick_color_options = NULL;
struct t_hook *irc_config_hook_config_chat_nick_colors = NULL;
struct t_hashtable *irc_config_hashtable_display_join_message = NULL;
@@ -2751,8 +2761,6 @@ irc_config_server_create_default_options (struct t_config_section *section)
int
irc_config_init ()
{
- struct t_config_section *ptr_section;
-
irc_config_hashtable_display_join_message = weechat_hashtable_new (
32,
WEECHAT_HASHTABLE_STRING,
@@ -2775,858 +2783,857 @@ irc_config_init ()
return 0;
/* look */
- ptr_section = weechat_config_new_section (irc_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
-
- irc_config_look_buffer_open_before_autojoin = weechat_config_new_option (
- irc_config_file, ptr_section,
- "buffer_open_before_autojoin", "boolean",
- N_("open channel buffer before the JOIN is received from server "
- "when it is auto joined (with server option \"autojoin\"); "
- "this is useful to open channels with always the same buffer "
- "numbers on startup"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_buffer_open_before_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "buffer_open_before_join", "boolean",
- N_("open channel buffer before the JOIN is received from server "
- "when it is manually joined (with /join command)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_buffer_switch_autojoin = weechat_config_new_option (
- irc_config_file, ptr_section,
- "buffer_switch_autojoin", "boolean",
- N_("auto switch to channel buffer when it is auto joined (with "
- "server option \"autojoin\")"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_buffer_switch_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "buffer_switch_join", "boolean",
- N_("auto switch to channel buffer when it is manually joined "
- "(with /join command)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_color_nicks_in_names = weechat_config_new_option (
- irc_config_file, ptr_section,
- "color_nicks_in_names", "boolean",
- N_("use nick color in output of /names (or list of nicks displayed "
- "when joining a channel)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_color_nicks_in_nicklist = weechat_config_new_option (
- irc_config_file, ptr_section,
- "color_nicks_in_nicklist", "boolean",
- N_("use nick color in nicklist"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_color_nicks_in_nicklist, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_color_nicks_in_server_messages = weechat_config_new_option (
- irc_config_file, ptr_section,
- "color_nicks_in_server_messages", "boolean",
- N_("use nick color in messages from server"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_color_pv_nick_like_channel = weechat_config_new_option (
- irc_config_file, ptr_section,
- "color_pv_nick_like_channel", "boolean",
- N_("use same nick color for channel and private"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_ctcp_time_format = weechat_config_new_option (
- irc_config_file, ptr_section,
- "ctcp_time_format", "string",
- N_("time format used in answer to message CTCP TIME (see man strftime "
- "for date/time specifiers)"),
- NULL, 0, 0, "%a, %d %b %Y %T %z", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_account_message = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_account_message", "boolean",
- N_("display ACCOUNT messages received when capability account-notify "
- "is enabled"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_away = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_away", "integer",
- N_("display message when (un)marking as away (off: do not display/send "
- "anything, local: display locally, channel: send action to channels)"),
- "off|local|channel", 0, 0, "local", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_display_away, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_display_ctcp_blocked = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_ctcp_blocked", "boolean",
- N_("display CTCP message even if it is blocked"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_ctcp_reply = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_ctcp_reply", "boolean",
- N_("display CTCP reply sent by WeeChat"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_ctcp_unknown = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_ctcp_unknown", "boolean",
- N_("display CTCP message even if it is unknown CTCP"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_extended_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_extended_join", "boolean",
- N_("display extra information in the JOIN messages: account name "
- "and real name (capability extended-join must be enabled)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_host_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_host_join", "boolean",
- N_("display host in join messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_host_join_local = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_host_join_local", "boolean",
- N_("display host in join messages from local client"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_host_quit = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_host_quit", "boolean",
- N_("display host in part/quit messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_join_message = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_join_message", "string",
- N_("comma-separated list of messages to display after joining a "
- "channel: 324 = channel modes, 329 = channel creation date, "
- "332 = topic, 333 = nick/date for topic, 353 = names on channel, "
- "366 = names count"),
- NULL, 0, 0, "329,332,333,366", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_display_join_message, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_display_old_topic = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_old_topic", "boolean",
- N_("display old topic when channel topic is changed"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_pv_away_once = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_pv_away_once", "boolean",
- N_("display remote away message only once in private"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_pv_back = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_pv_back", "boolean",
- N_("display a message in private when user is back (after quit on "
- "server)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_pv_nick_change = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_pv_nick_change", "boolean",
- N_("display nick change in private"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_display_pv_warning_address = weechat_config_new_option (
- irc_config_file, ptr_section,
- "display_pv_warning_address", "boolean",
- N_("display a warning in private buffer if the address of remote nick "
- "has changed; this option is disabled by default because servers "
- "like bitlbee are causing this warning to be displayed when it is "
- "not expected (the address of remote nick changes multiple times "
- "on login)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_highlight_channel = weechat_config_new_option (
- irc_config_file, ptr_section,
- "highlight_channel", "string",
- N_("comma separated list of words to highlight in channel buffers "
- "(case insensitive, use \"(?-i)\" at beginning of words to "
- "make them case sensitive; special variables $nick, $channel and "
- "$server are replaced by their values), these words are added to "
- "buffer property \"highlight_words\" only when buffer is created "
- "(it does not affect current buffers), an empty string disables "
- "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
- NULL, 0, 0, "$nick", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_highlight_pv = weechat_config_new_option (
- irc_config_file, ptr_section,
- "highlight_pv", "string",
- N_("comma separated list of words to highlight in private buffers "
- "(case insensitive, use \"(?-i)\" at beginning of words to "
- "make them case sensitive; special variables $nick, $channel and "
- "$server are replaced by their values), these words are added to "
- "buffer property \"highlight_words\" only when buffer is created "
- "(it does not affect current buffers), an empty string disables "
- "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
- NULL, 0, 0, "$nick", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_highlight_server = weechat_config_new_option (
- irc_config_file, ptr_section,
- "highlight_server", "string",
- N_("comma separated list of words to highlight in server buffers "
- "(case insensitive, use \"(?-i)\" at beginning of words to "
- "make them case sensitive; special variables $nick, $channel and "
- "$server are replaced by their values), these words are added to "
- "buffer property \"highlight_words\" only when buffer is created "
- "(it does not affect current buffers), an empty string disables "
- "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
- NULL, 0, 0, "$nick", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_highlight_tags_restrict = weechat_config_new_option (
- irc_config_file, ptr_section,
- "highlight_tags_restrict", "string",
- N_("restrict highlights to these tags on irc buffers (to have "
- "highlight on user messages but not server messages); tags "
- "must be separated by a comma and \"+\" can be used to make a "
- "logical \"and\" between tags; wildcard \"*\" is allowed in tags; "
- "an empty value allows highlight on any tag"),
- NULL, 0, 0, "irc_privmsg,irc_notice", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_highlight_tags_restrict, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_item_channel_modes_hide_args = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_channel_modes_hide_args", "string",
- N_("hide channel modes arguments if at least one of these modes is in "
- "channel modes (\"*\" to always hide all arguments, empty value to "
- "never hide arguments); example: \"kf\" to hide arguments if \"k\" "
- "or \"f\" are in channel modes"),
- NULL, 0, 0, "k", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_item_channel_modes_hide_args, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_item_display_server = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_display_server", "integer",
- N_("name of bar item where IRC server is displayed (for status bar)"),
- "buffer_plugin|buffer_name", 0, 0, "buffer_plugin", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_look_item_display_server, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_item_nick_modes = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_nick_modes", "boolean",
- N_("display nick modes in bar item \"input_prompt\""),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_bar_item_input_prompt, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_item_nick_prefix = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_nick_prefix", "boolean",
- N_("display nick prefix in bar item \"input_prompt\""),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_bar_item_input_prompt, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_join_auto_add_chantype = weechat_config_new_option (
- irc_config_file, ptr_section,
- "join_auto_add_chantype", "boolean",
- N_("automatically add channel type in front of channel name on "
- "command /join if the channel name does not start with a valid "
- "channel type for the server; for example: \"/join weechat\" will "
- "in fact send: \"/join #weechat\""),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_msgbuffer_fallback = weechat_config_new_option (
- irc_config_file, ptr_section,
- "msgbuffer_fallback", "integer",
- N_("default target buffer for msgbuffer options when target is "
- "private and that private buffer is not found"),
- "current|server", 0, 0, "current", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_new_channel_position = weechat_config_new_option (
- irc_config_file, ptr_section,
- "new_channel_position", "integer",
- N_("force position of new channel in list of buffers "
- "(none = default position (should be last buffer), "
- "next = current buffer + 1, near_server = after last channel/pv "
- "of server)"),
- "none|next|near_server", 0, 0, "none", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_new_pv_position = weechat_config_new_option (
- irc_config_file, ptr_section,
- "new_pv_position", "integer",
- N_("force position of new private in list of buffers "
- "(none = default position (should be last buffer), "
- "next = current buffer + 1, near_server = after last channel/pv "
- "of server)"),
- "none|next|near_server", 0, 0, "none", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_nick_completion_smart = weechat_config_new_option (
- irc_config_file, ptr_section,
- "nick_completion_smart", "integer",
- N_("smart completion for nicks (completes first with last speakers): "
- "speakers = all speakers (including highlights), "
- "speakers_highlights = only speakers with highlight"),
- "off|speakers|speakers_highlights", 0, 0, "speakers", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_nick_mode = weechat_config_new_option (
- irc_config_file, ptr_section,
- "nick_mode", "integer",
- N_("display nick mode (op, voice, ...) before nick (none = never, "
- "prefix = in prefix only (default), action = in action messages "
- "only, both = prefix + action messages)"),
- "none|prefix|action|both", 0, 0, "prefix", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_nick_mode_empty = weechat_config_new_option (
- irc_config_file, ptr_section,
- "nick_mode_empty", "boolean",
- N_("display a space if nick mode is enabled but nick has no mode (not "
- "op, voice, ...)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_bar_item_input_prompt, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_nicks_hide_password = weechat_config_new_option (
- irc_config_file, ptr_section,
- "nicks_hide_password", "string",
- N_("comma separated list of nicks for which passwords will be hidden "
- "when a message is sent, for example to hide password in message "
- "displayed by \"/msg nickserv identify password\", example: "
- "\"nickserv,nickbot\""),
- NULL, 0, 0, "nickserv", NULL, 0,
+ irc_config_section_look = weechat_config_new_section (
+ irc_config_file, "look",
+ 0, 0,
NULL, NULL, NULL,
- &irc_config_change_look_nicks_hide_password, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_notice_as_pv = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notice_as_pv", "integer",
- N_("display notices as private messages (if auto, use private buffer "
- "if found)"),
- "auto|never|always", 0, 0, "auto", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_notice_welcome_redirect = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notice_welcome_redirect", "boolean",
- N_("automatically redirect channel welcome notices to the channel "
- "buffer; such notices have the nick as target but a channel name "
- "in beginning of notice message, for example the ENTRYMSG notices "
- "sent by Atheme IRC Services which look like: "
- "\"[#channel] Welcome to this channel...\""),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_notice_welcome_tags = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notice_welcome_tags", "string",
- N_("comma separated list of tags used in a welcome notices redirected "
- "to a channel, for example: \"notify_private\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_notify_tags_ison = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notify_tags_ison", "string",
- N_("comma separated list of tags used in messages displayed by notify "
- "when a nick joins or quits server (result of command ison or "
- "monitor), for example: \"notify_message\", \"notify_private\" or "
- "\"notify_highlight\""),
- NULL, 0, 0, "notify_message", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_notify_tags_whois = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notify_tags_whois", "string",
- N_("comma separated list of tags used in messages displayed by notify "
- "when a nick away status changes (result of command whois), "
- "for example: \"notify_message\", \"notify_private\" or "
- "\"notify_highlight\""),
- NULL, 0, 0, "notify_message", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_part_closes_buffer = weechat_config_new_option (
- irc_config_file, ptr_section,
- "part_closes_buffer", "boolean",
- N_("close buffer when /part is issued on a channel"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_pv_buffer = weechat_config_new_option (
- irc_config_file, ptr_section,
- "pv_buffer", "integer",
- N_("merge private buffers"),
- "independent|merge_by_server|merge_all", 0, 0, "independent", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_look_pv_buffer, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_pv_tags = weechat_config_new_option (
- irc_config_file, ptr_section,
- "pv_tags", "string",
- N_("comma separated list of tags used in private messages, for example: "
- "\"notify_message\", \"notify_private\" or \"notify_highlight\""),
- NULL, 0, 0, "notify_private", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_raw_messages = weechat_config_new_option (
- irc_config_file, ptr_section,
- "raw_messages", "integer",
- N_("number of raw messages to save in memory when raw data buffer is "
- "closed (messages will be displayed when opening raw data buffer)"),
- NULL, 0, 65535, "256", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_typing_status_nicks = weechat_config_new_option (
- irc_config_file, ptr_section,
- "typing_status_nicks", "boolean",
- N_("display nicks typing on the channel in bar item \"typing\" "
- "(option typing.look.enabled_nicks must be enabled and capability "
- "\"message-tags\" must be enabled on the server)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_typing_status_self = weechat_config_new_option (
- irc_config_file, ptr_section,
- "typing_status_self", "boolean",
- N_("send self typing status to channels so that other users see when "
- "you are typing a message "
- "(option typing.look.enabled_self must be enabled and capability "
- "\"message-tags\" must be enabled on the server)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_server_buffer = weechat_config_new_option (
- irc_config_file, ptr_section,
- "server_buffer", "integer",
- N_("merge server buffers; this option has no effect if a layout "
- "is saved and is conflicting with this value (see /help layout)"),
- "merge_with_core|merge_without_core|independent", 0, 0, "merge_with_core",
- NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_look_server_buffer, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_look_smart_filter = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter", "boolean",
- N_("filter join/part/quit/nick messages for a nick if not speaking "
- "for some minutes on channel (you must create a filter on tag "
- "\"irc_smart_filter\", see /help filter)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_account = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_account", "boolean",
- /* TRANSLATORS: please do not translate "account" */
- N_("enable smart filter for \"account\" messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_chghost = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_chghost", "boolean",
- /* TRANSLATORS: please do not translate "chghost" */
- N_("enable smart filter for \"chghost\" messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_delay = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_delay", "integer",
- N_("delay for filtering join/part/quit messages (in minutes): if the "
- "nick did not speak during the last N minutes, the join/part/quit is "
- "filtered"),
- NULL, 1, 60*24*7, "5", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_join", "boolean",
- /* TRANSLATORS: please do not translate "join" */
- N_("enable smart filter for \"join\" messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_join_unmask = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_join_unmask", "integer",
- N_("delay for unmasking a join message that was filtered with tag "
- "\"irc_smart_filter\" (in minutes): if a nick has joined max N "
- "minutes ago and then says something on channel (message, notice or "
- "update on topic), the join is unmasked, as well as nick changes "
- "after this join (0 = disable: never unmask a join)"),
- NULL, 0, 60*24*7, "30", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_mode = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_mode", "string",
- /* TRANSLATORS: please do not translate "mode" */
- N_("enable smart filter for \"mode\" messages: \"*\" to filter all "
- "modes, \"+\" to filter all modes in server prefixes (for example "
- "\"ovh\"), \"xyz\" to filter only modes x/y/z, \"-xyz\" to filter "
- "all modes but not x/y/z; examples: \"ovh\": filter modes o/v/h, "
- "\"-bkl\": filter all modes but not b/k/l"),
- NULL, 0, 0, "+", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_nick = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_nick", "boolean",
- /* TRANSLATORS: please do not translate "nick" */
- N_("enable smart filter for \"nick\" messages (nick changes)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_quit = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_quit", "boolean",
- /* TRANSLATORS: please do not translate "part" and "quit" */
- N_("enable smart filter for \"part\" and \"quit\" messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_smart_filter_setname = weechat_config_new_option (
- irc_config_file, ptr_section,
- "smart_filter_setname", "boolean",
- /* TRANSLATORS: please do not translate "setname" */
- N_("enable smart filter for \"setname\" messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_temporary_servers = weechat_config_new_option (
- irc_config_file, ptr_section,
- "temporary_servers", "boolean",
- N_("enable automatic addition of temporary servers with command "
- "/connect"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_look_topic_strip_colors = weechat_config_new_option (
- irc_config_file, ptr_section,
- "topic_strip_colors", "boolean",
- N_("strip colors in topic (used only when displaying buffer title)"),
- NULL, 0, 0, "off", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_look_topic_strip_colors, NULL, NULL,
NULL, NULL, NULL);
-
- /* color */
- ptr_section = weechat_config_new_section (irc_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (irc_config_section_look)
{
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
+ irc_config_look_buffer_open_before_autojoin = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "buffer_open_before_autojoin", "boolean",
+ N_("open channel buffer before the JOIN is received from server "
+ "when it is auto joined (with server option \"autojoin\"); "
+ "this is useful to open channels with always the same buffer "
+ "numbers on startup"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_buffer_open_before_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "buffer_open_before_join", "boolean",
+ N_("open channel buffer before the JOIN is received from server "
+ "when it is manually joined (with /join command)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_buffer_switch_autojoin = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "buffer_switch_autojoin", "boolean",
+ N_("auto switch to channel buffer when it is auto joined (with "
+ "server option \"autojoin\")"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_buffer_switch_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "buffer_switch_join", "boolean",
+ N_("auto switch to channel buffer when it is manually joined "
+ "(with /join command)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_color_nicks_in_names = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "color_nicks_in_names", "boolean",
+ N_("use nick color in output of /names (or list of nicks displayed "
+ "when joining a channel)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_color_nicks_in_nicklist = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "color_nicks_in_nicklist", "boolean",
+ N_("use nick color in nicklist"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_color_nicks_in_nicklist, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_color_nicks_in_server_messages = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "color_nicks_in_server_messages", "boolean",
+ N_("use nick color in messages from server"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_color_pv_nick_like_channel = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "color_pv_nick_like_channel", "boolean",
+ N_("use same nick color for channel and private"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_ctcp_time_format = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "ctcp_time_format", "string",
+ N_("time format used in answer to message CTCP TIME (see man "
+ "strftime for date/time specifiers)"),
+ NULL, 0, 0, "%a, %d %b %Y %T %z", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_account_message = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_account_message", "boolean",
+ N_("display ACCOUNT messages received when capability account-notify "
+ "is enabled"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_away = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_away", "integer",
+ N_("display message when (un)marking as away (off: do not "
+ "display/send anything, local: display locally, channel: send "
+ "action to channels)"),
+ "off|local|channel", 0, 0, "local", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_display_away, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_display_ctcp_blocked = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_ctcp_blocked", "boolean",
+ N_("display CTCP message even if it is blocked"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_ctcp_reply = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_ctcp_reply", "boolean",
+ N_("display CTCP reply sent by WeeChat"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_ctcp_unknown = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_ctcp_unknown", "boolean",
+ N_("display CTCP message even if it is unknown CTCP"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_extended_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_extended_join", "boolean",
+ N_("display extra information in the JOIN messages: account name "
+ "and real name (capability extended-join must be enabled)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_host_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_host_join", "boolean",
+ N_("display host in join messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_host_join_local = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_host_join_local", "boolean",
+ N_("display host in join messages from local client"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_host_quit = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_host_quit", "boolean",
+ N_("display host in part/quit messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_join_message = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_join_message", "string",
+ N_("comma-separated list of messages to display after joining a "
+ "channel: 324 = channel modes, 329 = channel creation date, "
+ "332 = topic, 333 = nick/date for topic, 353 = names on channel, "
+ "366 = names count"),
+ NULL, 0, 0, "329,332,333,366", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_display_join_message, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_display_old_topic = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_old_topic", "boolean",
+ N_("display old topic when channel topic is changed"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_pv_away_once = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_pv_away_once", "boolean",
+ N_("display remote away message only once in private"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_pv_back = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_pv_back", "boolean",
+ N_("display a message in private when user is back (after quit on "
+ "server)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_pv_nick_change = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_pv_nick_change", "boolean",
+ N_("display nick change in private"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_display_pv_warning_address = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "display_pv_warning_address", "boolean",
+ N_("display a warning in private buffer if the address of remote "
+ "nick has changed; this option is disabled by default because "
+ "servers like bitlbee are causing this warning to be displayed "
+ "when it is not expected (the address of remote nick changes "
+ "multiple times on login)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_highlight_channel = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "highlight_channel", "string",
+ N_("comma separated list of words to highlight in channel buffers "
+ "(case insensitive, use \"(?-i)\" at beginning of words to "
+ "make them case sensitive; special variables $nick, $channel and "
+ "$server are replaced by their values), these words are added to "
+ "buffer property \"highlight_words\" only when buffer is created "
+ "(it does not affect current buffers), an empty string disables "
+ "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
+ NULL, 0, 0, "$nick", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_highlight_pv = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "highlight_pv", "string",
+ N_("comma separated list of words to highlight in private buffers "
+ "(case insensitive, use \"(?-i)\" at beginning of words to "
+ "make them case sensitive; special variables $nick, $channel and "
+ "$server are replaced by their values), these words are added to "
+ "buffer property \"highlight_words\" only when buffer is created "
+ "(it does not affect current buffers), an empty string disables "
+ "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
+ NULL, 0, 0, "$nick", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_highlight_server = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "highlight_server", "string",
+ N_("comma separated list of words to highlight in server buffers "
+ "(case insensitive, use \"(?-i)\" at beginning of words to "
+ "make them case sensitive; special variables $nick, $channel and "
+ "$server are replaced by their values), these words are added to "
+ "buffer property \"highlight_words\" only when buffer is created "
+ "(it does not affect current buffers), an empty string disables "
+ "default highlight on nick, examples: \"$nick\", \"(?-i)$nick\""),
+ NULL, 0, 0, "$nick", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_highlight_tags_restrict = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "highlight_tags_restrict", "string",
+ N_("restrict highlights to these tags on irc buffers (to have "
+ "highlight on user messages but not server messages); tags "
+ "must be separated by a comma and \"+\" can be used to make a "
+ "logical \"and\" between tags; wildcard \"*\" is allowed in tags; "
+ "an empty value allows highlight on any tag"),
+ NULL, 0, 0, "irc_privmsg,irc_notice", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_highlight_tags_restrict, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_item_channel_modes_hide_args = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "item_channel_modes_hide_args", "string",
+ N_("hide channel modes arguments if at least one of these modes is "
+ "in channel modes (\"*\" to always hide all arguments, empty "
+ "value to never hide arguments); example: \"kf\" to hide "
+ "arguments if \"k\" or \"f\" are in channel modes"),
+ NULL, 0, 0, "k", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_item_channel_modes_hide_args, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_item_display_server = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "item_display_server", "integer",
+ N_("name of bar item where IRC server is displayed (for status bar)"),
+ "buffer_plugin|buffer_name", 0, 0, "buffer_plugin", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_item_display_server, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_item_nick_modes = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "item_nick_modes", "boolean",
+ N_("display nick modes in bar item \"input_prompt\""),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_bar_item_input_prompt, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_item_nick_prefix = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "item_nick_prefix", "boolean",
+ N_("display nick prefix in bar item \"input_prompt\""),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_bar_item_input_prompt, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_join_auto_add_chantype = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "join_auto_add_chantype", "boolean",
+ N_("automatically add channel type in front of channel name on "
+ "command /join if the channel name does not start with a valid "
+ "channel type for the server; for example: \"/join weechat\" "
+ "will in fact send: \"/join #weechat\""),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_msgbuffer_fallback = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "msgbuffer_fallback", "integer",
+ N_("default target buffer for msgbuffer options when target is "
+ "private and that private buffer is not found"),
+ "current|server", 0, 0, "current", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_new_channel_position = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "new_channel_position", "integer",
+ N_("force position of new channel in list of buffers "
+ "(none = default position (should be last buffer), "
+ "next = current buffer + 1, near_server = after last channel/pv "
+ "of server)"),
+ "none|next|near_server", 0, 0, "none", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_new_pv_position = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "new_pv_position", "integer",
+ N_("force position of new private in list of buffers "
+ "(none = default position (should be last buffer), "
+ "next = current buffer + 1, near_server = after last channel/pv "
+ "of server)"),
+ "none|next|near_server", 0, 0, "none", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_nick_completion_smart = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "nick_completion_smart", "integer",
+ N_("smart completion for nicks (completes first with last speakers): "
+ "speakers = all speakers (including highlights), "
+ "speakers_highlights = only speakers with highlight"),
+ "off|speakers|speakers_highlights", 0, 0, "speakers", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_nick_mode = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "nick_mode", "integer",
+ N_("display nick mode (op, voice, ...) before nick (none = never, "
+ "prefix = in prefix only (default), action = in action messages "
+ "only, both = prefix + action messages)"),
+ "none|prefix|action|both", 0, 0, "prefix", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_nick_mode_empty = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "nick_mode_empty", "boolean",
+ N_("display a space if nick mode is enabled but nick has no mode "
+ "(not op, voice, ...)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_bar_item_input_prompt, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_nicks_hide_password = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "nicks_hide_password", "string",
+ N_("comma separated list of nicks for which passwords will be "
+ "hidden when a message is sent, for example to hide password "
+ "in message displayed by \"/msg nickserv identify password\", "
+ "example: \"nickserv,nickbot\""),
+ NULL, 0, 0, "nickserv", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_nicks_hide_password, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_notice_as_pv = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "notice_as_pv", "integer",
+ N_("display notices as private messages (if auto, use private "
+ "buffer if found)"),
+ "auto|never|always", 0, 0, "auto", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_notice_welcome_redirect = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "notice_welcome_redirect", "boolean",
+ N_("automatically redirect channel welcome notices to the channel "
+ "buffer; such notices have the nick as target but a channel name "
+ "in beginning of notice message, for example the ENTRYMSG "
+ "notices sent by Atheme IRC Services which look like: "
+ "\"[#channel] Welcome to this channel...\""),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_notice_welcome_tags = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "notice_welcome_tags", "string",
+ N_("comma separated list of tags used in a welcome notices "
+ "redirected to a channel, for example: \"notify_private\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_notify_tags_ison = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "notify_tags_ison", "string",
+ N_("comma separated list of tags used in messages displayed by "
+ "notify when a nick joins or quits server (result of command "
+ "ison or monitor), for example: \"notify_message\", "
+ "\"notify_private\" or \"notify_highlight\""),
+ NULL, 0, 0, "notify_message", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_notify_tags_whois = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "notify_tags_whois", "string",
+ N_("comma separated list of tags used in messages displayed by "
+ "notify when a nick away status changes (result of command "
+ "whois), for example: \"notify_message\", \"notify_private\" or "
+ "\"notify_highlight\""),
+ NULL, 0, 0, "notify_message", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_part_closes_buffer = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "part_closes_buffer", "boolean",
+ N_("close buffer when /part is issued on a channel"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_pv_buffer = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "pv_buffer", "integer",
+ N_("merge private buffers"),
+ "independent|merge_by_server|merge_all", 0, 0, "independent", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_pv_buffer, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_pv_tags = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "pv_tags", "string",
+ N_("comma separated list of tags used in private messages, for "
+ "example: \"notify_message\", \"notify_private\" or "
+ "\"notify_highlight\""),
+ NULL, 0, 0, "notify_private", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_raw_messages = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "raw_messages", "integer",
+ N_("number of raw messages to save in memory when raw data buffer "
+ "is closed (messages will be displayed when opening raw data "
+ "buffer)"),
+ NULL, 0, 65535, "256", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_typing_status_nicks = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "typing_status_nicks", "boolean",
+ N_("display nicks typing on the channel in bar item \"typing\" "
+ "(option typing.look.enabled_nicks must be enabled and "
+ "capability \"message-tags\" must be enabled on the server)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_typing_status_self = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "typing_status_self", "boolean",
+ N_("send self typing status to channels so that other users see "
+ "when you are typing a message "
+ "(option typing.look.enabled_self must be enabled and capability "
+ "\"message-tags\" must be enabled on the server)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_server_buffer = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "server_buffer", "integer",
+ N_("merge server buffers; this option has no effect if a layout "
+ "is saved and is conflicting with this value (see /help layout)"),
+ "merge_with_core|merge_without_core|independent", 0, 0, "merge_with_core",
+ NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_server_buffer, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_look_smart_filter = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter", "boolean",
+ N_("filter join/part/quit/nick messages for a nick if not speaking "
+ "for some minutes on channel (you must create a filter on tag "
+ "\"irc_smart_filter\", see /help filter)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_account = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_account", "boolean",
+ /* TRANSLATORS: please do not translate "account" */
+ N_("enable smart filter for \"account\" messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_chghost = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_chghost", "boolean",
+ /* TRANSLATORS: please do not translate "chghost" */
+ N_("enable smart filter for \"chghost\" messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_delay = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_delay", "integer",
+ N_("delay for filtering join/part/quit messages (in minutes): if "
+ "the nick did not speak during the last N minutes, the "
+ "join/part/quit is filtered"),
+ NULL, 1, 60*24*7, "5", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_join", "boolean",
+ /* TRANSLATORS: please do not translate "join" */
+ N_("enable smart filter for \"join\" messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_join_unmask = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_join_unmask", "integer",
+ N_("delay for unmasking a join message that was filtered with tag "
+ "\"irc_smart_filter\" (in minutes): if a nick has joined max N "
+ "minutes ago and then says something on channel (message, "
+ "notice or update on topic), the join is unmasked, as well as "
+ "nick changes after this join (0 = disable: never unmask a "
+ "join)"),
+ NULL, 0, 60*24*7, "30", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_mode = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_mode", "string",
+ /* TRANSLATORS: please do not translate "mode" */
+ N_("enable smart filter for \"mode\" messages: \"*\" to filter all "
+ "modes, \"+\" to filter all modes in server prefixes (for example "
+ "\"ovh\"), \"xyz\" to filter only modes x/y/z, \"-xyz\" to filter "
+ "all modes but not x/y/z; examples: \"ovh\": filter modes o/v/h, "
+ "\"-bkl\": filter all modes but not b/k/l"),
+ NULL, 0, 0, "+", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_nick = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_nick", "boolean",
+ /* TRANSLATORS: please do not translate "nick" */
+ N_("enable smart filter for \"nick\" messages (nick changes)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_quit = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_quit", "boolean",
+ /* TRANSLATORS: please do not translate "part" and "quit" */
+ N_("enable smart filter for \"part\" and \"quit\" messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_smart_filter_setname = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "smart_filter_setname", "boolean",
+ /* TRANSLATORS: please do not translate "setname" */
+ N_("enable smart filter for \"setname\" messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_temporary_servers = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "temporary_servers", "boolean",
+ N_("enable automatic addition of temporary servers with command "
+ "/connect"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_look_topic_strip_colors = weechat_config_new_option (
+ irc_config_file, irc_config_section_look,
+ "topic_strip_colors", "boolean",
+ N_("strip colors in topic (used only when displaying buffer title)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_look_topic_strip_colors, NULL, NULL,
+ NULL, NULL, NULL);
}
- irc_config_color_input_nick = weechat_config_new_option (
- irc_config_file, ptr_section,
- "input_nick", "color",
- N_("color for nick in input bar"),
- NULL, -1, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_bar_item_input_prompt, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_channel_modes = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_channel_modes", "color",
- N_("color for channel modes, near channel name"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_color_item_channel_modes, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_lag_counting = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_lag_counting", "color",
- N_("color for lag indicator, when counting (pong not received from "
- "server, lag is increasing)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_color_item_lag, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_lag_finished = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_lag_finished", "color",
- N_("color for lag indicator, when pong has been received from server"),
- NULL, -1, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_color_item_lag, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_nick_modes = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_nick_modes", "color",
- N_("color for nick modes in bar item \"input_prompt\""),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_color_item_nick_modes, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_tls_version_deprecated = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_tls_version_deprecated", "color",
- N_("color for deprecated TLS versions in bar item \"tls_version\""),
- NULL, -1, 0, "yellow", NULL, 0,
+ /* color */
+ irc_config_section_color = weechat_config_new_section (
+ irc_config_file, "color",
+ 0, 0,
NULL, NULL, NULL,
- &irc_config_change_color_item_tls_version, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_tls_version_insecure = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_tls_version_insecure", "color",
- N_("color for insecure TLS versions in bar item \"tls_version\""),
- NULL, -1, 0, "red", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_color_item_tls_version, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_item_tls_version_ok = weechat_config_new_option (
- irc_config_file, ptr_section,
- "item_tls_version_ok", "color",
- N_("color for higher supported TLS version in bar item \"tls_version\""),
- NULL, -1, 0, "green", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_color_item_tls_version, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_message_account = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_account", "color",
- N_("color for text in account messages"),
- NULL, -1, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_message_chghost = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_chghost", "color",
- /* TRANSLATORS: please do not translate "chghost" */
- N_("color for text in \"chghost\" messages"),
- NULL, -1, 0, "brown", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_message_join = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_join", "color",
- N_("color for text in join messages"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_message_kick = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_kick", "color",
- N_("color for text in kick/kill messages"),
- NULL, -1, 0, "red", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_message_quit = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_quit", "color",
- N_("color for text in part/quit messages"),
- NULL, -1, 0, "red", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_message_setname = weechat_config_new_option (
- irc_config_file, ptr_section,
- "message_setname", "color",
- /* TRANSLATORS: please do not translate "setname" */
- N_("color for text in \"setname\" messages"),
- NULL, -1, 0, "brown", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_mirc_remap = weechat_config_new_option (
- irc_config_file, ptr_section,
- "mirc_remap", "string",
- /* TRANSLATORS: please do not translate the list of WeeChat color names at the end of string */
- N_("remap mirc colors in messages using a hashtable: keys are \"fg,bg\" "
- "as integers between -1 (not specified) and 15, values are WeeChat "
- "color names or numbers (format is: \"1,-1:color1;2,7:color2\"), "
- "example: \"1,-1:darkgray;1,2:white,blue\" to remap black to "
- "\"darkgray\" and black on blue to \"white,blue\"; default "
- "WeeChat colors for IRC codes: 0=white, 1=black, 2=blue, 3=green, "
- "4=lightred, 5=red, 6=magenta, 7=brown, 8=yellow, 9=lightgreen, "
- "10=cyan, 11=lightcyan, 12=lightblue, 13=lightmagenta, "
- "14=darkgray, 15=gray"),
- NULL, 0, 0, "1,-1:darkgray", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_color_mirc_remap, NULL, NULL,
NULL, NULL, NULL);
- irc_config_color_nick_prefixes = weechat_config_new_option (
- irc_config_file, ptr_section,
- "nick_prefixes", "string",
- N_("color for nick prefixes using mode char (o=op, h=halfop, v=voice, "
- "..), format is: \"o:color1;h:color2;v:color3\" (if a mode is not "
- "found, WeeChat will try with next modes received from server "
- "(\"PREFIX\"); a special mode \"*\" can be used as default color "
- "if no mode has been found in list)"),
- NULL, 0, 0, "y:lightred;q:lightred;a:lightcyan;o:lightgreen;"
- "h:lightmagenta;v:yellow;*:lightblue", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_color_nick_prefixes, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_color_notice = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notice", "color",
- N_("color for text \"Notice\" in notices"),
- NULL, -1, 0, "green", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_reason_kick = weechat_config_new_option (
- irc_config_file, ptr_section,
- "reason_kick", "color",
- N_("color for reason in kick/kill messages"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_reason_quit = weechat_config_new_option (
- irc_config_file, ptr_section,
- "reason_quit", "color",
- N_("color for reason in part/quit messages"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_topic_current = weechat_config_new_option (
- irc_config_file, ptr_section,
- "topic_current", "color",
- N_("color for current channel topic (when joining a channel or "
- "using /topic)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_topic_new = weechat_config_new_option (
- irc_config_file, ptr_section,
- "topic_new", "color",
- N_("color for new channel topic (when topic is changed)"),
- NULL, -1, 0, "white", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_color_topic_old = weechat_config_new_option (
- irc_config_file, ptr_section,
- "topic_old", "color",
- N_("color for old channel topic (when topic is changed)"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- /* network */
- ptr_section = weechat_config_new_section (irc_config_file, "network",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (irc_config_section_color)
{
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
+ irc_config_color_input_nick = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "input_nick", "color",
+ N_("color for nick in input bar"),
+ NULL, -1, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_bar_item_input_prompt, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_channel_modes = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_channel_modes", "color",
+ N_("color for channel modes, near channel name"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_channel_modes, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_lag_counting = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_lag_counting", "color",
+ N_("color for lag indicator, when counting (pong not received from "
+ "server, lag is increasing)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_lag, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_lag_finished = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_lag_finished", "color",
+ N_("color for lag indicator, when pong has been received from server"),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_lag, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_nick_modes = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_nick_modes", "color",
+ N_("color for nick modes in bar item \"input_prompt\""),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_nick_modes, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_tls_version_deprecated = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_tls_version_deprecated", "color",
+ N_("color for deprecated TLS versions in bar item \"tls_version\""),
+ NULL, -1, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_tls_version, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_tls_version_insecure = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_tls_version_insecure", "color",
+ N_("color for insecure TLS versions in bar item \"tls_version\""),
+ NULL, -1, 0, "red", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_tls_version, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_item_tls_version_ok = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "item_tls_version_ok", "color",
+ N_("color for higher supported TLS version in bar item "
+ "\"tls_version\""),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_item_tls_version, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_message_account = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_account", "color",
+ N_("color for text in account messages"),
+ NULL, -1, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_message_chghost = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_chghost", "color",
+ /* TRANSLATORS: please do not translate "chghost" */
+ N_("color for text in \"chghost\" messages"),
+ NULL, -1, 0, "brown", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_message_join = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_join", "color",
+ N_("color for text in join messages"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_message_kick = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_kick", "color",
+ N_("color for text in kick/kill messages"),
+ NULL, -1, 0, "red", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_message_quit = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_quit", "color",
+ N_("color for text in part/quit messages"),
+ NULL, -1, 0, "red", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_message_setname = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "message_setname", "color",
+ /* TRANSLATORS: please do not translate "setname" */
+ N_("color for text in \"setname\" messages"),
+ NULL, -1, 0, "brown", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_mirc_remap = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "mirc_remap", "string",
+ /* TRANSLATORS: please do not translate the list of WeeChat color names at the end of string */
+ N_("remap mirc colors in messages using a hashtable: keys are "
+ "\"fg,bg\" as integers between -1 (not specified) and 15, "
+ "values are WeeChat color names or numbers (format is: "
+ "\"1,-1:color1;2,7:color2\"), example: "
+ "\"1,-1:darkgray;1,2:white,blue\" to remap black to "
+ "\"darkgray\" and black on blue to \"white,blue\"; default "
+ "WeeChat colors for IRC codes: 0=white, 1=black, 2=blue, "
+ "3=green, 4=lightred, 5=red, 6=magenta, 7=brown, 8=yellow, "
+ "9=lightgreen, 10=cyan, 11=lightcyan, 12=lightblue, "
+ "13=lightmagenta, 14=darkgray, 15=gray"),
+ NULL, 0, 0, "1,-1:darkgray", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_mirc_remap, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_nick_prefixes = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "nick_prefixes", "string",
+ N_("color for nick prefixes using mode char (o=op, h=halfop, "
+ "v=voice, ..), format is: \"o:color1;h:color2;v:color3\" (if a "
+ "mode is not found, WeeChat will try with next modes received "
+ "from server (\"PREFIX\"); a special mode \"*\" can be used as "
+ "default color if no mode has been found in list)"),
+ NULL, 0, 0, "y:lightred;q:lightred;a:lightcyan;o:lightgreen;"
+ "h:lightmagenta;v:yellow;*:lightblue", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_color_nick_prefixes, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_color_notice = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "notice", "color",
+ N_("color for text \"Notice\" in notices"),
+ NULL, -1, 0, "green", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_reason_kick = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "reason_kick", "color",
+ N_("color for reason in kick/kill messages"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_reason_quit = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "reason_quit", "color",
+ N_("color for reason in part/quit messages"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_topic_current = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "topic_current", "color",
+ N_("color for current channel topic (when joining a channel or "
+ "using /topic)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_topic_new = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "topic_new", "color",
+ N_("color for new channel topic (when topic is changed)"),
+ NULL, -1, 0, "white", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_color_topic_old = weechat_config_new_option (
+ irc_config_file, irc_config_section_color,
+ "topic_old", "color",
+ N_("color for old channel topic (when topic is changed)"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- irc_config_network_autoreconnect_delay_growing = weechat_config_new_option (
- irc_config_file, ptr_section,
- "autoreconnect_delay_growing", "integer",
- N_("growing factor for autoreconnect delay to server (1 = always same "
- "delay, 2 = delay*2 for each retry, etc.)"),
- NULL, 1, 100, "2", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_autoreconnect_delay_max = weechat_config_new_option (
- irc_config_file, ptr_section,
- "autoreconnect_delay_max", "integer",
- N_("maximum autoreconnect delay to server (in seconds, 0 = no maximum)"),
- NULL, 0, 3600 * 24 * 7, "600", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_ban_mask_default = weechat_config_new_option (
- irc_config_file, ptr_section,
- "ban_mask_default", "string",
- N_("default ban mask for commands /ban, /unban and /kickban; variables "
- "$nick, $user, $ident and $host are replaced by their values "
- "(extracted from \"nick!user@host\"); $ident is the same as $user if "
- "$user does not start with \"~\", otherwise it is set to \"*\"; this "
- "default mask is used only if WeeChat knows the host for the nick"),
- NULL, 0, 0, "*!$ident@$host", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_colors_receive = weechat_config_new_option (
- irc_config_file, ptr_section,
- "colors_receive", "boolean",
- N_("when off, colors codes are ignored in incoming messages"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_colors_send = weechat_config_new_option (
- irc_config_file, ptr_section,
- "colors_send", "boolean",
- N_("allow user to send colors with special codes (ctrl-c + a code and "
- "optional color: b=bold, cxx=color, cxx,yy=color+background, "
- "i=italic, o=disable color/attributes, r=reverse, u=underline)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_lag_check = weechat_config_new_option (
- irc_config_file, ptr_section,
- "lag_check", "integer",
- N_("interval between two checks for lag (in seconds, 0 = never "
- "check)"),
- NULL, 0, 3600 * 24 * 7, "60", NULL, 0,
- NULL, NULL, NULL,
- &irc_config_change_network_lag_check, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_network_lag_max = weechat_config_new_option (
- irc_config_file, ptr_section,
- "lag_max", "integer",
- N_("maximum lag (in seconds): if this lag is reached, WeeChat will "
- "consider that the answer from server (pong) will never be received "
- "and will give up counting the lag (0 = never give up)"),
- NULL, 0, 3600 * 24 * 7, "1800", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_lag_min_show = weechat_config_new_option (
- irc_config_file, ptr_section,
- "lag_min_show", "integer",
- N_("minimum lag to show (in milliseconds)"),
- NULL, 0, 1000 * 3600 * 24, "500", NULL, 0,
+ /* network */
+ irc_config_section_network = weechat_config_new_section (
+ irc_config_file, "network",
+ 0, 0,
NULL, NULL, NULL,
- &irc_config_change_network_lag_min_show, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_network_lag_reconnect = weechat_config_new_option (
- irc_config_file, ptr_section,
- "lag_reconnect", "integer",
- N_("reconnect to server if lag is greater than or equal to this value "
- "(in seconds, 0 = never reconnect); this value must be less than or "
- "equal to irc.network.lag_max"),
- NULL, 0, 3600 * 24 * 7, "300", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_lag_refresh_interval = weechat_config_new_option (
- irc_config_file, ptr_section,
- "lag_refresh_interval", "integer",
- N_("interval between two refreshes of lag item, when lag is "
- "increasing (in seconds)"),
- NULL, 1, 3600, "1", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_notify_check_ison = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notify_check_ison", "integer",
- N_("interval between two checks for notify with IRC command \"ison\" "
- "(in minutes)"),
- NULL, 1, 60 * 24 * 7, "1", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_network_notify_check_ison, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_network_notify_check_whois = weechat_config_new_option (
- irc_config_file, ptr_section,
- "notify_check_whois", "integer",
- N_("interval between two checks for notify with IRC command \"whois\" "
- "(in minutes)"),
- NULL, 1, 60 * 24 * 7, "5", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_network_notify_check_whois, NULL, NULL,
- NULL, NULL, NULL);
- irc_config_network_sasl_fail_unavailable = weechat_config_new_option (
- irc_config_file, ptr_section,
- "sasl_fail_unavailable", "boolean",
- N_("cause SASL authentication failure when SASL is requested but "
- "unavailable on the server; when this option is enabled, it has "
- "effect only if option \"sasl_fail\" is set to \"reconnect\" or "
- "\"disconnect\" in the server"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- irc_config_network_send_unknown_commands = weechat_config_new_option (
- irc_config_file, ptr_section,
- "send_unknown_commands", "boolean",
- N_("send unknown commands to server"),
- NULL, 0, 0, "off", NULL, 0,
NULL, NULL, NULL,
- &irc_config_change_network_send_unknown_commands, NULL, NULL,
NULL, NULL, NULL);
- irc_config_network_whois_double_nick = weechat_config_new_option (
- irc_config_file, ptr_section,
- "whois_double_nick", "boolean",
- N_("double the nick in /whois command (if only one nick is given), to "
- "get idle time in answer; for example: \"/whois nick\" will send "
- "\"whois nick nick\""),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ if (irc_config_section_network)
+ {
+ irc_config_network_autoreconnect_delay_growing = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "autoreconnect_delay_growing", "integer",
+ N_("growing factor for autoreconnect delay to server (1 = always "
+ "same delay, 2 = delay*2 for each retry, etc.)"),
+ NULL, 1, 100, "2", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_autoreconnect_delay_max = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "autoreconnect_delay_max", "integer",
+ N_("maximum autoreconnect delay to server (in seconds, 0 = no "
+ "maximum)"),
+ NULL, 0, 3600 * 24 * 7, "600", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_ban_mask_default = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "ban_mask_default", "string",
+ N_("default ban mask for commands /ban, /unban and /kickban; "
+ "variables $nick, $user, $ident and $host are replaced by their "
+ "values (extracted from \"nick!user@host\"); $ident is the same "
+ "as $user if $user does not start with \"~\", otherwise it is "
+ "set to \"*\"; this default mask is used only if WeeChat knows "
+ "the host for the nick"),
+ NULL, 0, 0, "*!$ident@$host", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_colors_receive = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "colors_receive", "boolean",
+ N_("when off, colors codes are ignored in incoming messages"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_colors_send = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "colors_send", "boolean",
+ N_("allow user to send colors with special codes (ctrl-c + a code "
+ "and optional color: b=bold, cxx=color, cxx,yy=color+background, "
+ "i=italic, o=disable color/attributes, r=reverse, u=underline)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_lag_check = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "lag_check", "integer",
+ N_("interval between two checks for lag (in seconds, 0 = never "
+ "check)"),
+ NULL, 0, 3600 * 24 * 7, "60", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_network_lag_check, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_network_lag_max = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "lag_max", "integer",
+ N_("maximum lag (in seconds): if this lag is reached, WeeChat will "
+ "consider that the answer from server (pong) will never be "
+ "received and will give up counting the lag (0 = never give up)"),
+ NULL, 0, 3600 * 24 * 7, "1800", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_lag_min_show = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "lag_min_show", "integer",
+ N_("minimum lag to show (in milliseconds)"),
+ NULL, 0, 1000 * 3600 * 24, "500", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_network_lag_min_show, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_network_lag_reconnect = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "lag_reconnect", "integer",
+ N_("reconnect to server if lag is greater than or equal to this "
+ "value (in seconds, 0 = never reconnect); this value must be "
+ "less than or equal to irc.network.lag_max"),
+ NULL, 0, 3600 * 24 * 7, "300", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_lag_refresh_interval = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "lag_refresh_interval", "integer",
+ N_("interval between two refreshes of lag item, when lag is "
+ "increasing (in seconds)"),
+ NULL, 1, 3600, "1", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_notify_check_ison = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "notify_check_ison", "integer",
+ N_("interval between two checks for notify with IRC command "
+ "\"ison\" (in minutes)"),
+ NULL, 1, 60 * 24 * 7, "1", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_network_notify_check_ison, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_network_notify_check_whois = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "notify_check_whois", "integer",
+ N_("interval between two checks for notify with IRC command "
+ "\"whois\" (in minutes)"),
+ NULL, 1, 60 * 24 * 7, "5", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_network_notify_check_whois, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_network_sasl_fail_unavailable = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "sasl_fail_unavailable", "boolean",
+ N_("cause SASL authentication failure when SASL is requested but "
+ "unavailable on the server; when this option is enabled, it has "
+ "effect only if option \"sasl_fail\" is set to \"reconnect\" or "
+ "\"disconnect\" in the server"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ irc_config_network_send_unknown_commands = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "send_unknown_commands", "boolean",
+ N_("send unknown commands to server"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &irc_config_change_network_send_unknown_commands, NULL, NULL,
+ NULL, NULL, NULL);
+ irc_config_network_whois_double_nick = weechat_config_new_option (
+ irc_config_file, irc_config_section_network,
+ "whois_double_nick", "boolean",
+ N_("double the nick in /whois command (if only one nick is given), "
+ "to get idle time in answer; for example: \"/whois nick\" will "
+ "send \"whois nick nick\""),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ }
/* msgbuffer */
- ptr_section = weechat_config_new_section (
+ irc_config_section_msgbuffer = weechat_config_new_section (
irc_config_file, "msgbuffer",
1, 1,
NULL, NULL, NULL,
@@ -3634,16 +3641,9 @@ irc_config_init ()
NULL, NULL, NULL,
&irc_config_msgbuffer_create_option, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
- irc_config_section_msgbuffer = ptr_section;
/* CTCP */
- ptr_section = weechat_config_new_section (
+ irc_config_section_ctcp = weechat_config_new_section (
irc_config_file, "ctcp",
1, 1,
NULL, NULL, NULL,
@@ -3651,16 +3651,9 @@ irc_config_init ()
NULL, NULL, NULL,
&irc_config_ctcp_create_option, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
- irc_config_section_ctcp = ptr_section;
/* ignore */
- ptr_section = weechat_config_new_section (
+ irc_config_section_ignore = weechat_config_new_section (
irc_config_file, "ignore",
0, 0,
&irc_config_ignore_read_cb, NULL, NULL,
@@ -3668,15 +3661,9 @@ irc_config_init ()
&irc_config_ignore_write_cb, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
/* server_default */
- ptr_section = weechat_config_new_section (
+ irc_config_section_server_default = weechat_config_new_section (
irc_config_file, "server_default",
0, 0,
NULL, NULL, NULL,
@@ -3684,18 +3671,11 @@ irc_config_init ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
- irc_config_section_server_default = ptr_section;
- irc_config_server_create_default_options (ptr_section);
+ irc_config_server_create_default_options (irc_config_section_server_default);
/* server */
- ptr_section = weechat_config_new_section (
+ irc_config_section_server = weechat_config_new_section (
irc_config_file, "server",
0, 0,
&irc_config_server_read_cb, NULL, NULL,
@@ -3703,13 +3683,6 @@ irc_config_init ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (irc_config_file);
- irc_config_file = NULL;
- return 0;
- }
- irc_config_section_server = ptr_section;
irc_config_hook_config_nick_color_options = weechat_hook_config (
"weechat.look.nick_color_*",
diff --git a/src/plugins/logger/logger-config.c b/src/plugins/logger/logger-config.c
index d254cabe3..646d3a0ba 100644
--- a/src/plugins/logger/logger-config.c
+++ b/src/plugins/logger/logger-config.c
@@ -30,6 +30,12 @@
struct t_config_file *logger_config_file = NULL;
+
+/* sections */
+
+struct t_config_section *logger_config_section_look = NULL;
+struct t_config_section *logger_config_section_color = NULL;
+struct t_config_section *logger_config_section_file = NULL;
struct t_config_section *logger_config_section_level = NULL;
struct t_config_section *logger_config_section_mask = NULL;
@@ -37,31 +43,31 @@ int logger_config_loading = 0;
/* logger config, look section */
-struct t_config_option *logger_config_look_backlog;
-struct t_config_option *logger_config_look_backlog_conditions;
+struct t_config_option *logger_config_look_backlog = NULL;
+struct t_config_option *logger_config_look_backlog_conditions = NULL;
/* logger config, color section */
-struct t_config_option *logger_config_color_backlog_end;
-struct t_config_option *logger_config_color_backlog_line;
+struct t_config_option *logger_config_color_backlog_end = NULL;
+struct t_config_option *logger_config_color_backlog_line = NULL;
/* logger config, file section */
-struct t_config_option *logger_config_file_auto_log;
-struct t_config_option *logger_config_file_color_lines;
-struct t_config_option *logger_config_file_flush_delay;
-struct t_config_option *logger_config_file_fsync;
-struct t_config_option *logger_config_file_info_lines;
-struct t_config_option *logger_config_file_mask;
-struct t_config_option *logger_config_file_name_lower_case;
-struct t_config_option *logger_config_file_nick_prefix;
-struct t_config_option *logger_config_file_nick_suffix;
-struct t_config_option *logger_config_file_path;
-struct t_config_option *logger_config_file_replacement_char;
-struct t_config_option *logger_config_file_rotation_compression_level;
-struct t_config_option *logger_config_file_rotation_compression_type;
-struct t_config_option *logger_config_file_rotation_size_max;
-struct t_config_option *logger_config_file_time_format;
+struct t_config_option *logger_config_file_auto_log = NULL;
+struct t_config_option *logger_config_file_color_lines = NULL;
+struct t_config_option *logger_config_file_flush_delay = NULL;
+struct t_config_option *logger_config_file_fsync = NULL;
+struct t_config_option *logger_config_file_info_lines = NULL;
+struct t_config_option *logger_config_file_mask = NULL;
+struct t_config_option *logger_config_file_name_lower_case = NULL;
+struct t_config_option *logger_config_file_nick_prefix = NULL;
+struct t_config_option *logger_config_file_nick_suffix = NULL;
+struct t_config_option *logger_config_file_path = NULL;
+struct t_config_option *logger_config_file_replacement_char = NULL;
+struct t_config_option *logger_config_file_rotation_compression_level = NULL;
+struct t_config_option *logger_config_file_rotation_compression_type = NULL;
+struct t_config_option *logger_config_file_rotation_size_max = NULL;
+struct t_config_option *logger_config_file_time_format = NULL;
/* other */
@@ -460,234 +466,224 @@ logger_config_get_mask (const char *name)
int
logger_config_init ()
{
- struct t_config_section *ptr_section;
-
logger_config_file = weechat_config_new (LOGGER_CONFIG_PRIO_NAME,
NULL, NULL, NULL);
if (!logger_config_file)
return 0;
/* look */
- ptr_section = weechat_config_new_section (logger_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ logger_config_section_look = weechat_config_new_section (
+ logger_config_file, "look",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ if (logger_config_section_look)
{
- weechat_config_free (logger_config_file);
- logger_config_file = NULL;
- return 0;
+ logger_config_look_backlog = weechat_config_new_option (
+ logger_config_file, logger_config_section_look,
+ "backlog", "integer",
+ N_("maximum number of lines to display from log file when creating "
+ "new buffer (0 = no backlog)"),
+ NULL, 0, INT_MAX, "20", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_look_backlog_conditions = weechat_config_new_option (
+ logger_config_file, logger_config_section_look,
+ "backlog_conditions", "string",
+ N_("conditions to display the backlog "
+ "(note: content is evaluated, see /help eval); "
+ "empty value displays the backlog on all buffers; "
+ "for example to display backlog on private buffers only: "
+ "\"${type} == private\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- logger_config_look_backlog = weechat_config_new_option (
- logger_config_file, ptr_section,
- "backlog", "integer",
- N_("maximum number of lines to display from log file when creating "
- "new buffer (0 = no backlog)"),
- NULL, 0, INT_MAX, "20", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_look_backlog_conditions = weechat_config_new_option (
- logger_config_file, ptr_section,
- "backlog_conditions", "string",
- N_("conditions to display the backlog "
- "(note: content is evaluated, see /help eval); "
- "empty value displays the backlog on all buffers; "
- "for example to display backlog on private buffers only: "
- "\"${type} == private\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* color */
- ptr_section = weechat_config_new_section (logger_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ logger_config_section_color = weechat_config_new_section (
+ logger_config_file, "color",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ if (logger_config_section_color)
{
- weechat_config_free (logger_config_file);
- logger_config_file = NULL;
- return 0;
+ logger_config_color_backlog_end = weechat_config_new_option (
+ logger_config_file, logger_config_section_color,
+ "backlog_end", "color",
+ N_("color for line ending the backlog"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_color_backlog_line = weechat_config_new_option (
+ logger_config_file, logger_config_section_color,
+ "backlog_line", "color",
+ N_("color for backlog lines, used only if the option "
+ "logger.file.color_lines is off"),
+ NULL, -1, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- logger_config_color_backlog_end = weechat_config_new_option (
- logger_config_file, ptr_section,
- "backlog_end", "color",
- N_("color for line ending the backlog"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_color_backlog_line = weechat_config_new_option (
- logger_config_file, ptr_section,
- "backlog_line", "color",
- N_("color for backlog lines, used only if the option "
- "logger.file.color_lines is off"),
- NULL, -1, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* file */
- ptr_section = weechat_config_new_section (logger_config_file, "file",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (logger_config_file);
- logger_config_file = NULL;
- return 0;
- }
-
- logger_config_file_auto_log = weechat_config_new_option (
- logger_config_file, ptr_section,
- "auto_log", "boolean",
- N_("automatically save content of buffers to files (unless a buffer "
- "disables log); if disabled, logging is disabled on all buffers"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_color_lines = weechat_config_new_option (
- logger_config_file, ptr_section,
- "color_lines", "boolean",
- N_("use ANSI color codes in lines written in log files and display "
- "backlog lines with these colors"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &logger_config_color_lines_change, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_flush_delay = weechat_config_new_option (
- logger_config_file, ptr_section,
- "flush_delay", "integer",
- N_("number of seconds between flush of log files (0 = write in log "
- "files immediately for each line printed)"),
- NULL, 0, 3600, "120", NULL, 0,
- NULL, NULL, NULL,
- &logger_config_flush_delay_change, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_fsync = weechat_config_new_option (
- logger_config_file, ptr_section,
- "fsync", "boolean",
- N_("use fsync to synchronize the log file with the storage device "
- "after the flush (see man fsync); this is slower but should "
- "prevent any data loss in case of power failure during the save of "
- "log file"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_info_lines = weechat_config_new_option (
- logger_config_file, ptr_section,
- "info_lines", "boolean",
- N_("write information line in log file when log starts or ends for a "
- "buffer"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_mask = weechat_config_new_option (
- logger_config_file, ptr_section,
- "mask", "string",
- N_("default file name mask for log files (format is "
- "\"directory/to/file\" or \"file\", without first \"/\" because "
- "\"path\" option is used to build complete path to file); local "
- "buffer variables are permitted (you should use only variables "
- "that are defined on all buffers, so for example you should NOT "
- "use $server nor $channel); date specifiers are permitted "
- "(see man strftime)"),
- NULL, 0, 0, "$plugin.$name.weechatlog", NULL, 0,
+ logger_config_section_file = weechat_config_new_section (
+ logger_config_file, "file",
+ 0, 0,
NULL, NULL, NULL,
- &logger_config_change_file_option_restart_log, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_name_lower_case = weechat_config_new_option (
- logger_config_file, ptr_section,
- "name_lower_case", "boolean",
- N_("use only lower case for log filenames"),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
- &logger_config_change_file_option_restart_log, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_nick_prefix = weechat_config_new_option (
- logger_config_file, ptr_section,
- "nick_prefix", "string",
- N_("text to write before nick in prefix of message, example: \"<\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_nick_suffix = weechat_config_new_option (
- logger_config_file, ptr_section,
- "nick_suffix", "string",
- N_("text to write after nick in prefix of message, example: \">\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_path = weechat_config_new_option (
- logger_config_file, ptr_section,
- "path", "string",
- N_("path for WeeChat log files; "
- "date specifiers are permitted (see man strftime) "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_data_dir}/logs", NULL, 0,
NULL, NULL, NULL,
- &logger_config_change_file_option_restart_log, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_replacement_char = weechat_config_new_option (
- logger_config_file, ptr_section,
- "replacement_char", "string",
- N_("replacement char for special chars in filename built with mask "
- "(like directory delimiter)"),
- NULL, 0, 0, "_", NULL, 0,
NULL, NULL, NULL,
- &logger_config_change_file_option_restart_log, NULL, NULL,
NULL, NULL, NULL);
- logger_config_file_rotation_compression_level = weechat_config_new_option (
- logger_config_file, ptr_section,
- "rotation_compression_level", "integer",
- N_("compression level for rotated log files (with extension \".1\", "
- "\".2\", etc.), if option logger.file.rotation_compression_type is "
- "enabled: 1 = low compression / fast ... 100 = best compression / "
- "slow; the value is a percentage converted to 1-9 for gzip and "
- "1-19 for zstd; the default value is recommended, it offers a good "
- "compromise between compression and speed"),
- NULL, 1, 100, "20", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_rotation_compression_type = weechat_config_new_option (
- logger_config_file, ptr_section,
- "rotation_compression_type", "integer",
- N_("compression type for rotated log files; if set to \"none\", "
- "rotated log files are not compressed; WARNING: if rotation was "
- "enabled with another type of compression (or no compression), "
- "you must first unload the logger plugin, compress files with the "
- "new type (or decompress files), then change the option in "
- "logger.conf, then load the logger plugin"),
- "none|gzip|zstd", 0, 0, "none", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- logger_config_file_rotation_size_max = weechat_config_new_option (
- logger_config_file, ptr_section,
- "rotation_size_max", "string",
- N_("when this size is reached, a rotation of log files is performed: "
- "the existing rotated log files are renamed (.1 becomes .2, .2 "
- "becomes .3, etc.) and the current file is renamed with extension "
- ".1; an integer number with a suffix is allowed: b = bytes "
- "(default if no unit given), k = kilobytes, m = megabytes, "
- "g = gigabytes, t = terabytes; example: \"2g\" causes a rotation "
- "if the file size is > 2,000,000,000 bytes; if set to \"0\", "
- "no rotation is performed (unlimited log size); WARNING: before "
- "changing this option, you should first set the compression type "
- "via option logger.file.rotation_compression_type"),
- NULL, 0, 0, "0", NULL, 0,
- &logger_config_rotation_size_max_check, NULL, NULL,
- &logger_config_rotation_size_max_change, NULL, NULL,
- NULL, NULL, NULL);
- logger_config_file_time_format = weechat_config_new_option (
- logger_config_file, ptr_section,
- "time_format", "string",
- N_("timestamp used in log files (see man strftime for date/time "
- "specifiers)"),
- NULL, 0, 0, "%Y-%m-%d %H:%M:%S", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ if (logger_config_section_file)
+ {
+ logger_config_file_auto_log = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "auto_log", "boolean",
+ N_("automatically save content of buffers to files (unless a buffer "
+ "disables log); if disabled, logging is disabled on all buffers"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_color_lines = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "color_lines", "boolean",
+ N_("use ANSI color codes in lines written in log files and display "
+ "backlog lines with these colors"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_color_lines_change, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_flush_delay = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "flush_delay", "integer",
+ N_("number of seconds between flush of log files (0 = write in log "
+ "files immediately for each line printed)"),
+ NULL, 0, 3600, "120", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_flush_delay_change, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_fsync = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "fsync", "boolean",
+ N_("use fsync to synchronize the log file with the storage device "
+ "after the flush (see man fsync); this is slower but should "
+ "prevent any data loss in case of power failure during the save "
+ "of log file"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_info_lines = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "info_lines", "boolean",
+ N_("write information line in log file when log starts or ends for "
+ "a buffer"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_mask = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "mask", "string",
+ N_("default file name mask for log files (format is "
+ "\"directory/to/file\" or \"file\", without first \"/\" because "
+ "\"path\" option is used to build complete path to file); local "
+ "buffer variables are permitted (you should use only variables "
+ "that are defined on all buffers, so for example you should NOT "
+ "use $server nor $channel); date specifiers are permitted "
+ "(see man strftime)"),
+ NULL, 0, 0, "$plugin.$name.weechatlog", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_change_file_option_restart_log, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_name_lower_case = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "name_lower_case", "boolean",
+ N_("use only lower case for log filenames"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_change_file_option_restart_log, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_nick_prefix = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "nick_prefix", "string",
+ N_("text to write before nick in prefix of message, example: \"<\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_nick_suffix = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "nick_suffix", "string",
+ N_("text to write after nick in prefix of message, example: \">\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_path = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "path", "string",
+ N_("path for WeeChat log files; "
+ "date specifiers are permitted (see man strftime) "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_data_dir}/logs", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_change_file_option_restart_log, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_replacement_char = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "replacement_char", "string",
+ N_("replacement char for special chars in filename built with mask "
+ "(like directory delimiter)"),
+ NULL, 0, 0, "_", NULL, 0,
+ NULL, NULL, NULL,
+ &logger_config_change_file_option_restart_log, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_rotation_compression_level = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "rotation_compression_level", "integer",
+ N_("compression level for rotated log files (with extension \".1\", "
+ "\".2\", etc.), if option logger.file.rotation_compression_type "
+ "is enabled: 1 = low compression / fast ... 100 = best "
+ "compression / slow; the value is a percentage converted to "
+ "1-9 for gzip and 1-19 for zstd; the default value is "
+ "recommended, it offers a good compromise between compression "
+ "and speed"),
+ NULL, 1, 100, "20", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_rotation_compression_type = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "rotation_compression_type", "integer",
+ N_("compression type for rotated log files; if set to \"none\", "
+ "rotated log files are not compressed; WARNING: if rotation was "
+ "enabled with another type of compression (or no compression), "
+ "you must first unload the logger plugin, compress files with the "
+ "new type (or decompress files), then change the option in "
+ "logger.conf, then load the logger plugin"),
+ "none|gzip|zstd", 0, 0, "none", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ logger_config_file_rotation_size_max = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "rotation_size_max", "string",
+ N_("when this size is reached, a rotation of log files is performed: "
+ "the existing rotated log files are renamed (.1 becomes .2, .2 "
+ "becomes .3, etc.) and the current file is renamed with extension "
+ ".1; an integer number with a suffix is allowed: b = bytes "
+ "(default if no unit given), k = kilobytes, m = megabytes, "
+ "g = gigabytes, t = terabytes; example: \"2g\" causes a rotation "
+ "if the file size is > 2,000,000,000 bytes; if set to \"0\", "
+ "no rotation is performed (unlimited log size); WARNING: before "
+ "changing this option, you should first set the compression type "
+ "via option logger.file.rotation_compression_type"),
+ NULL, 0, 0, "0", NULL, 0,
+ &logger_config_rotation_size_max_check, NULL, NULL,
+ &logger_config_rotation_size_max_change, NULL, NULL,
+ NULL, NULL, NULL);
+ logger_config_file_time_format = weechat_config_new_option (
+ logger_config_file, logger_config_section_file,
+ "time_format", "string",
+ N_("timestamp used in log files (see man strftime for date/time "
+ "specifiers)"),
+ NULL, 0, 0, "%Y-%m-%d %H:%M:%S", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ }
/* level */
- ptr_section = weechat_config_new_section (
+ logger_config_section_level = weechat_config_new_section (
logger_config_file, "level",
1, 1,
NULL, NULL, NULL,
@@ -695,17 +691,9 @@ logger_config_init ()
NULL, NULL, NULL,
&logger_config_level_create_option, NULL, NULL,
&logger_config_level_delete_option, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (logger_config_file);
- logger_config_file = NULL;
- return 0;
- }
-
- logger_config_section_level = ptr_section;
/* mask */
- ptr_section = weechat_config_new_section (
+ logger_config_section_mask = weechat_config_new_section (
logger_config_file, "mask",
1, 1,
NULL, NULL, NULL,
@@ -713,14 +701,6 @@ logger_config_init ()
NULL, NULL, NULL,
&logger_config_mask_create_option, NULL, NULL,
&logger_config_mask_delete_option, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (logger_config_file);
- logger_config_file = NULL;
- return 0;
- }
-
- logger_config_section_mask = ptr_section;
return 1;
}
diff --git a/src/plugins/plugin-config.c b/src/plugins/plugin-config.c
index df2c2cbf5..14f717439 100644
--- a/src/plugins/plugin-config.c
+++ b/src/plugins/plugin-config.c
@@ -378,11 +378,6 @@ plugin_config_init ()
&plugin_config_create_desc, NULL, NULL,
&plugin_config_delete_desc, NULL, NULL);
}
- else
- {
- plugin_config_section_var = NULL;
- plugin_config_section_desc = NULL;
- }
}
/*
diff --git a/src/plugins/plugin-script-config.c b/src/plugins/plugin-script-config.c
index 5893c87ed..fb357ff2b 100644
--- a/src/plugins/plugin-script-config.c
+++ b/src/plugins/plugin-script-config.c
@@ -60,30 +60,27 @@ plugin_script_config_init (struct t_weechat_plugin *weechat_plugin,
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
+ if (ptr_section)
{
- weechat_config_free (*(plugin_data->config_file));
- *(plugin_data->config_file) = NULL;
- return 0;
+ *(plugin_data->config_look_check_license) = weechat_config_new_option (
+ *(plugin_data->config_file), ptr_section,
+ "check_license", "boolean",
+ N_("check the license of scripts when they are loaded: if the "
+ "license is different from the plugin license, a warning is "
+ "displayed"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ *(plugin_data->config_look_eval_keep_context) = weechat_config_new_option (
+ *(plugin_data->config_file), ptr_section,
+ "eval_keep_context", "boolean",
+ N_("keep context between two calls to the source code evaluation "
+ "(option \"eval\" of script command or info \"%s_eval\"); "
+ "a hidden script is used to eval script code; "
+ "if this option is disabled, this hidden script is unloaded "
+ "after each eval: this uses less memory, but is slower"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- *(plugin_data->config_look_check_license) = weechat_config_new_option (
- *(plugin_data->config_file), ptr_section,
- "check_license", "boolean",
- N_("check the license of scripts when they are loaded: if the license "
- "is different from the plugin license, a warning is displayed"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- *(plugin_data->config_look_eval_keep_context) = weechat_config_new_option (
- *(plugin_data->config_file), ptr_section,
- "eval_keep_context", "boolean",
- N_("keep context between two calls to the source code evaluation "
- "(option \"eval\" of script command or info \"%s_eval\"); "
- "a hidden script is used to eval script code; "
- "if this option is disabled, this hidden script is unloaded after "
- "each eval: this uses less memory, but is slower"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
return 1;
}
diff --git a/src/plugins/relay/relay-config.c b/src/plugins/relay/relay-config.c
index a7591befa..126905784 100644
--- a/src/plugins/relay/relay-config.c
+++ b/src/plugins/relay/relay-config.c
@@ -40,54 +40,64 @@
struct t_config_file *relay_config_file = NULL;
+
+/* sections */
+
+struct t_config_section *relay_config_section_look = NULL;
+struct t_config_section *relay_config_section_color = NULL;
+struct t_config_section *relay_config_section_network = NULL;
+struct t_config_section *relay_config_section_irc = NULL;
+struct t_config_section *relay_config_section_weechat = NULL;
struct t_config_section *relay_config_section_port = NULL;
struct t_config_section *relay_config_section_path = NULL;
/* relay config, look section */
-struct t_config_option *relay_config_look_auto_open_buffer;
-struct t_config_option *relay_config_look_raw_messages;
+struct t_config_option *relay_config_look_auto_open_buffer = NULL;
+struct t_config_option *relay_config_look_raw_messages = NULL;
/* relay config, color section */
-struct t_config_option *relay_config_color_client;
-struct t_config_option *relay_config_color_status[RELAY_NUM_STATUS];
-struct t_config_option *relay_config_color_text;
-struct t_config_option *relay_config_color_text_bg;
-struct t_config_option *relay_config_color_text_selected;
+struct t_config_option *relay_config_color_client = NULL;
+struct t_config_option *relay_config_color_status[RELAY_NUM_STATUS] = {
+ NULL, NULL, NULL, NULL, NULL,
+};
+struct t_config_option *relay_config_color_text = NULL;
+struct t_config_option *relay_config_color_text_bg = NULL;
+struct t_config_option *relay_config_color_text_selected = NULL;
/* relay config, network section */
-struct t_config_option *relay_config_network_allow_empty_password;
-struct t_config_option *relay_config_network_allowed_ips;
-struct t_config_option *relay_config_network_auth_timeout;
-struct t_config_option *relay_config_network_bind_address;
-struct t_config_option *relay_config_network_clients_purge_delay;
-struct t_config_option *relay_config_network_compression;
-struct t_config_option *relay_config_network_ipv6;
-struct t_config_option *relay_config_network_max_clients;
-struct t_config_option *relay_config_network_nonce_size;
-struct t_config_option *relay_config_network_password;
-struct t_config_option *relay_config_network_password_hash_algo;
-struct t_config_option *relay_config_network_password_hash_iterations;
-struct t_config_option *relay_config_network_ssl_cert_key;
-struct t_config_option *relay_config_network_ssl_priorities;
-struct t_config_option *relay_config_network_totp_secret;
-struct t_config_option *relay_config_network_totp_window;
-struct t_config_option *relay_config_network_websocket_allowed_origins;
+struct t_config_option *relay_config_network_allow_empty_password = NULL;
+struct t_config_option *relay_config_network_allowed_ips = NULL;
+struct t_config_option *relay_config_network_auth_timeout = NULL;
+struct t_config_option *relay_config_network_bind_address = NULL;
+struct t_config_option *relay_config_network_clients_purge_delay = NULL;
+struct t_config_option *relay_config_network_compression = NULL;
+struct t_config_option *relay_config_network_ipv6 = NULL;
+struct t_config_option *relay_config_network_max_clients = NULL;
+struct t_config_option *relay_config_network_nonce_size = NULL;
+struct t_config_option *relay_config_network_password = NULL;
+struct t_config_option *relay_config_network_password_hash_algo = NULL;
+struct t_config_option *relay_config_network_password_hash_iterations = NULL;
+struct t_config_option *relay_config_network_ssl_cert_key = NULL;
+struct t_config_option *relay_config_network_ssl_priorities = NULL;
+struct t_config_option *relay_config_network_totp_secret = NULL;
+struct t_config_option *relay_config_network_totp_window = NULL;
+struct t_config_option *relay_config_network_websocket_allowed_origins = NULL;
/* relay config, irc section */
-struct t_config_option *relay_config_irc_backlog_max_minutes;
-struct t_config_option *relay_config_irc_backlog_max_number;
-struct t_config_option *relay_config_irc_backlog_since_last_disconnect;
-struct t_config_option *relay_config_irc_backlog_since_last_message;
-struct t_config_option *relay_config_irc_backlog_tags;
-struct t_config_option *relay_config_irc_backlog_time_format;
+struct t_config_option *relay_config_irc_backlog_max_minutes = NULL;
+struct t_config_option *relay_config_irc_backlog_max_number = NULL;
+struct t_config_option *relay_config_irc_backlog_since_last_disconnect = NULL;
+struct t_config_option *relay_config_irc_backlog_since_last_message = NULL;
+struct t_config_option *relay_config_irc_backlog_tags = NULL;
+struct t_config_option *relay_config_irc_backlog_time_format = NULL;
/* relay config, weechat section */
-struct t_config_option *relay_config_weechat_commands;
+struct t_config_option *relay_config_weechat_commands = NULL;
/* other */
@@ -889,411 +899,396 @@ relay_config_reload (const void *pointer, void *data,
int
relay_config_init ()
{
- struct t_config_section *ptr_section;
-
relay_config_file = weechat_config_new (RELAY_CONFIG_PRIO_NAME,
&relay_config_reload, NULL, NULL);
if (!relay_config_file)
return 0;
/* section look */
- ptr_section = weechat_config_new_section (relay_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
- }
-
- relay_config_look_auto_open_buffer = weechat_config_new_option (
- relay_config_file, ptr_section,
- "auto_open_buffer", "boolean",
- N_("auto open relay buffer when a new client is connecting"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_look_raw_messages = weechat_config_new_option (
- relay_config_file, ptr_section,
- "raw_messages", "integer",
- N_("number of raw messages to save in memory when raw data buffer is "
- "closed (messages will be displayed when opening raw data buffer)"),
- NULL, 0, 65535, "256", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- /* section color */
- ptr_section = weechat_config_new_section (relay_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
- }
-
- relay_config_color_client = weechat_config_new_option (
- relay_config_file, ptr_section,
- "client", "color",
- N_("text color for client description"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_color_status[RELAY_STATUS_CONNECTED] = weechat_config_new_option (
- relay_config_file, ptr_section,
- "status_active", "color",
- N_("text color for \"connected\" status"),
- NULL, 0, 0, "green", NULL, 0,
+ relay_config_section_look = weechat_config_new_section (
+ relay_config_file, "look",
+ 0, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_status[RELAY_STATUS_AUTH_FAILED] = weechat_config_new_option (
- relay_config_file, ptr_section,
- "status_auth_failed", "color",
- N_("text color for \"authentication failed\" status"),
- NULL, 0, 0, "lightmagenta", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_status[RELAY_STATUS_CONNECTING] = weechat_config_new_option (
- relay_config_file, ptr_section,
- "status_connecting", "color",
- N_("text color for \"connecting\" status"),
- NULL, 0, 0, "white", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_status[RELAY_STATUS_DISCONNECTED] = weechat_config_new_option (
- relay_config_file, ptr_section,
- "status_disconnected", "color",
- N_("text color for \"disconnected\" status"),
- NULL, 0, 0, "lightred", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
- relay_config_color_status[RELAY_STATUS_WAITING_AUTH] = weechat_config_new_option (
- relay_config_file, ptr_section,
- "status_waiting_auth", "color",
- N_("text color for \"waiting authentication\" status"),
- NULL, 0, 0, "yellow", NULL, 0,
+ if (relay_config_section_look)
+ {
+ relay_config_look_auto_open_buffer = weechat_config_new_option (
+ relay_config_file, relay_config_section_look,
+ "auto_open_buffer", "boolean",
+ N_("auto open relay buffer when a new client is connecting"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_look_raw_messages = weechat_config_new_option (
+ relay_config_file, relay_config_section_look,
+ "raw_messages", "integer",
+ N_("number of raw messages to save in memory when raw data buffer "
+ "is closed (messages will be displayed when opening raw data "
+ "buffer)"),
+ NULL, 0, 65535, "256", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ }
+
+ /* section color */
+ relay_config_section_color = weechat_config_new_section (
+ relay_config_file, "color",
+ 0, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_text = weechat_config_new_option (
- relay_config_file, ptr_section,
- "text", "color",
- N_("text color in relay buffer"),
- NULL, 0, 0, "default", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_text_bg = weechat_config_new_option (
- relay_config_file, ptr_section,
- "text_bg", "color",
- N_("background color in relay buffer"),
- NULL, 0, 0, "default", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_color_text_selected = weechat_config_new_option (
- relay_config_file, ptr_section,
- "text_selected", "color",
- N_("text color of selected line in relay buffer"),
- NULL, 0, 0, "white", NULL, 0,
NULL, NULL, NULL,
- &relay_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
-
- /* section network */
- ptr_section = weechat_config_new_section (relay_config_file, "network",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (relay_config_section_color)
{
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
+ relay_config_color_client = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "client", "color",
+ N_("text color for client description"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_color_status[RELAY_STATUS_CONNECTED] = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "status_active", "color",
+ N_("text color for \"connected\" status"),
+ NULL, 0, 0, "green", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_status[RELAY_STATUS_AUTH_FAILED] = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "status_auth_failed", "color",
+ N_("text color for \"authentication failed\" status"),
+ NULL, 0, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_status[RELAY_STATUS_CONNECTING] = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "status_connecting", "color",
+ N_("text color for \"connecting\" status"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_status[RELAY_STATUS_DISCONNECTED] = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "status_disconnected", "color",
+ N_("text color for \"disconnected\" status"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_status[RELAY_STATUS_WAITING_AUTH] = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "status_waiting_auth", "color",
+ N_("text color for \"waiting authentication\" status"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_text = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "text", "color",
+ N_("text color in relay buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_text_bg = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "text_bg", "color",
+ N_("background color in relay buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_color_text_selected = weechat_config_new_option (
+ relay_config_file, relay_config_section_color,
+ "text_selected", "color",
+ N_("text color of selected line in relay buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
}
- relay_config_network_allow_empty_password = weechat_config_new_option (
- relay_config_file, ptr_section,
- "allow_empty_password", "boolean",
- N_("allow empty password in relay (it should be enabled only for "
- "tests or local network)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_allowed_ips = weechat_config_new_option (
- relay_config_file, ptr_section,
- "allowed_ips", "string",
- N_("POSIX extended regular expression with IPs allowed to use relay "
- "(case insensitive, use \"(?-i)\" at beginning to make it case "
- "sensitive), example: "
- "\"^(123\\.45\\.67\\.89|192\\.160\\..*)$\""),
- NULL, 0, 0, "", NULL, 0,
+ /* section network */
+ relay_config_section_network = weechat_config_new_section (
+ relay_config_file, "network",
+ 0, 0,
NULL, NULL, NULL,
- &relay_config_change_network_allowed_ips, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_auth_timeout = weechat_config_new_option (
- relay_config_file, ptr_section,
- "auth_timeout", "integer",
- N_("timeout (in seconds) for client authentication: connection is "
- "closed if the client is still not authenticated after this delay "
- "and the client status is set to \"authentication failed\" "
- "(0 = wait forever)"),
- NULL, 0, INT_MAX, "60", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_bind_address = weechat_config_new_option (
- relay_config_file, ptr_section,
- "bind_address", "string",
- N_("address for bind (if empty, connection is possible on all "
- "interfaces, use \"127.0.0.1\" to allow connections from "
- "local machine only)"),
- NULL, 0, 0, "", NULL, 0,
NULL, NULL, NULL,
- &relay_config_change_network_bind_address_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_clients_purge_delay = weechat_config_new_option (
- relay_config_file, ptr_section,
- "clients_purge_delay", "integer",
- N_("delay for purging disconnected clients (in minutes, 0 = purge "
- "clients immediately, -1 = never purge)"),
- NULL, -1, 60 * 24 * 30, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_compression = weechat_config_new_option (
- relay_config_file, ptr_section,
- "compression", "integer",
- N_("compression of messages sent to clients with \"weechat\" "
- "protocol: 0 = disable compression, 1 = low compression / fast "
- "... 100 = best compression / slow; the value is a percentage "
- "converted to 1-9 for zlib and 1-19 for zstd; "
- "the default value is recommended, it offers a good "
- "compromise between compression and speed"),
- NULL, 0, 100, "20", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_ipv6 = weechat_config_new_option (
- relay_config_file, ptr_section,
- "ipv6", "boolean",
- N_("listen on IPv6 socket by default (in addition to IPv4 which is "
- "default); protocols IPv4 and IPv6 can be forced (individually or "
- "together) in the protocol name (see /help relay)"),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
- &relay_config_change_network_ipv6_cb, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_max_clients = weechat_config_new_option (
- relay_config_file, ptr_section,
- "max_clients", "integer",
- N_("maximum number of clients connecting to a port (0 = no limit)"),
- NULL, 0, INT_MAX, "5", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_nonce_size = weechat_config_new_option (
- relay_config_file, ptr_section,
- "nonce_size", "integer",
- N_("size of nonce (in bytes), generated when a client connects; "
- "the client must use this nonce, concatenated to the client nonce "
- "and the password when hashing the password in the \"init\" "
- "command of the weechat protocol"),
- NULL, 8, 128, "16", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_password = weechat_config_new_option (
- relay_config_file, ptr_section,
- "password", "string",
- N_("password required by clients to access this relay (empty value "
- "means no password required, see option "
- "relay.network.allow_empty_password) (note: content is evaluated, "
- "see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_password_hash_algo = weechat_config_new_option (
- relay_config_file, ptr_section,
- "password_hash_algo", "string",
- N_("comma separated list of hash algorithms used for password "
- "authentication in weechat protocol, among these values: \"plain\" "
- "(password in plain text, not hashed), \"sha256\", \"sha512\", "
- "\"pbkdf2+sha256\", \"pbkdf2+sha512\"), \"*\" means all algorithms, "
- "a name beginning with \"!\" is a negative value to prevent an "
- "algorithm from being used, wildcard \"*\" is allowed in names "
- "(examples: \"*\", \"pbkdf2*\", \"*,!plain\")"),
- NULL, 0, 0, "*", NULL, 0,
NULL, NULL, NULL,
- &relay_config_change_network_password_hash_algo, NULL, NULL,
NULL, NULL, NULL);
- relay_config_network_password_hash_iterations = weechat_config_new_option (
- relay_config_file, ptr_section,
- "password_hash_iterations", "integer",
- N_("number of iterations asked to the client in weechat protocol "
- "when a hashed password with algorithm PBKDF2 is used for "
- "authentication; more iterations is better in term of security but "
- "is slower to compute; this number should not be too high if your "
- "CPU is slow"),
- NULL, 1, 1000000, "100000", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_ssl_cert_key = weechat_config_new_option (
- relay_config_file, ptr_section,
- "ssl_cert_key", "string",
- N_("file with SSL certificate and private key (for serving clients "
- "with SSL) "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_config_dir}/ssl/relay.pem", NULL, 0,
+ if (relay_config_section_network)
+ {
+ relay_config_network_allow_empty_password = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "allow_empty_password", "boolean",
+ N_("allow empty password in relay (it should be enabled only for "
+ "tests or local network)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_allowed_ips = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "allowed_ips", "string",
+ N_("POSIX extended regular expression with IPs allowed to use relay "
+ "(case insensitive, use \"(?-i)\" at beginning to make it case "
+ "sensitive), example: "
+ "\"^(123\\.45\\.67\\.89|192\\.160\\..*)$\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_allowed_ips, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_auth_timeout = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "auth_timeout", "integer",
+ N_("timeout (in seconds) for client authentication: connection is "
+ "closed if the client is still not authenticated after this "
+ "delay and the client status is set to \"authentication "
+ "failed\" (0 = wait forever)"),
+ NULL, 0, INT_MAX, "60", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_bind_address = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "bind_address", "string",
+ N_("address for bind (if empty, connection is possible on all "
+ "interfaces, use \"127.0.0.1\" to allow connections from "
+ "local machine only)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_bind_address_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_clients_purge_delay = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "clients_purge_delay", "integer",
+ N_("delay for purging disconnected clients (in minutes, 0 = purge "
+ "clients immediately, -1 = never purge)"),
+ NULL, -1, 60 * 24 * 30, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_compression = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "compression", "integer",
+ N_("compression of messages sent to clients with \"weechat\" "
+ "protocol: 0 = disable compression, 1 = low compression / fast "
+ "... 100 = best compression / slow; the value is a percentage "
+ "converted to 1-9 for zlib and 1-19 for zstd; "
+ "the default value is recommended, it offers a good "
+ "compromise between compression and speed"),
+ NULL, 0, 100, "20", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_ipv6 = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "ipv6", "boolean",
+ N_("listen on IPv6 socket by default (in addition to IPv4 which is "
+ "default); protocols IPv4 and IPv6 can be forced (individually "
+ "or together) in the protocol name (see /help relay)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_ipv6_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_max_clients = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "max_clients", "integer",
+ N_("maximum number of clients connecting to a port (0 = no limit)"),
+ NULL, 0, INT_MAX, "5", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_nonce_size = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "nonce_size", "integer",
+ N_("size of nonce (in bytes), generated when a client connects; "
+ "the client must use this nonce, concatenated to the client nonce "
+ "and the password when hashing the password in the \"init\" "
+ "command of the weechat protocol"),
+ NULL, 8, 128, "16", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_password = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "password", "string",
+ N_("password required by clients to access this relay (empty value "
+ "means no password required, see option "
+ "relay.network.allow_empty_password) (note: content is evaluated, "
+ "see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_password_hash_algo = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "password_hash_algo", "string",
+ N_("comma separated list of hash algorithms used for password "
+ "authentication in weechat protocol, among these values: "
+ "\"plain\" (password in plain text, not hashed), \"sha256\", "
+ "\"sha512\", \"pbkdf2+sha256\", \"pbkdf2+sha512\"), \"*\" means "
+ "all algorithms, a name beginning with \"!\" is a negative "
+ "value to prevent an algorithm from being used, wildcard \"*\" "
+ "is allowed in names (examples: \"*\", \"pbkdf2*\", "
+ "\"*,!plain\")"),
+ NULL, 0, 0, "*", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_password_hash_algo, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_password_hash_iterations = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "password_hash_iterations", "integer",
+ N_("number of iterations asked to the client in weechat protocol "
+ "when a hashed password with algorithm PBKDF2 is used for "
+ "authentication; more iterations is better in term of security "
+ "but is slower to compute; this number should not be too high "
+ "if your CPU is slow"),
+ NULL, 1, 1000000, "100000", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_ssl_cert_key = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "ssl_cert_key", "string",
+ N_("file with SSL certificate and private key (for serving clients "
+ "with SSL) "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_config_dir}/ssl/relay.pem", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_ssl_cert_key, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_ssl_priorities = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "ssl_priorities", "string",
+ N_("string with priorities for gnutls (for syntax, see "
+ "documentation of function gnutls_priority_init in gnutls "
+ "manual, common strings are: \"PERFORMANCE\", \"NORMAL\", "
+ "\"SECURE128\", \"SECURE256\", \"EXPORT\", \"NONE\")"),
+ NULL, 0, 0, "NORMAL:-VERS-SSL3.0", NULL, 0,
+ &relay_config_check_network_ssl_priorities, NULL, NULL,
+ &relay_config_change_network_ssl_priorities, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_totp_secret = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "totp_secret", "string",
+ N_("secret for the generation of the Time-based One-Time Password "
+ "(TOTP), encoded in base32 (only letters and digits from 2 to 7); "
+ "it is used as second factor in weechat protocol, in addition to "
+ "the password, which must not be empty "
+ "(empty value means no TOTP is required) "
+ "(note: content is evaluated, see /help eval)"),
+ NULL, 0, 0, "", NULL, 0,
+ &relay_config_check_network_totp_secret, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_network_totp_window = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "totp_window", "integer",
+ N_("number of Time-based One-Time Passwords to accept before and "
+ "after the current one: "
+ "0 = accept only the current password, "
+ "1 = accept one password before, the current, and one after, "
+ "2 = accept two passwords before, the current, and two after, "
+ "...; a high number reduces the security level "
+ "(0 or 1 are recommended values)"),
+ NULL, 0, 256, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_network_websocket_allowed_origins = weechat_config_new_option (
+ relay_config_file, relay_config_section_network,
+ "websocket_allowed_origins", "string",
+ N_("POSIX extended regular expression with origins allowed in "
+ "websockets (case insensitive, use \"(?-i)\" at beginning to "
+ "make it case sensitive), example: "
+ "\"^https?://(www\\.)?example\\.(com|org)\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &relay_config_change_network_websocket_allowed_origins, NULL, NULL,
+ NULL, NULL, NULL);
+ }
+
+ /* section irc */
+ relay_config_section_irc = weechat_config_new_section (
+ relay_config_file, "irc",
+ 0, 0,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &relay_config_change_network_ssl_cert_key, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_ssl_priorities = weechat_config_new_option (
- relay_config_file, ptr_section,
- "ssl_priorities", "string",
- N_("string with priorities for gnutls (for syntax, see "
- "documentation of function gnutls_priority_init in gnutls "
- "manual, common strings are: \"PERFORMANCE\", \"NORMAL\", "
- "\"SECURE128\", \"SECURE256\", \"EXPORT\", \"NONE\")"),
- NULL, 0, 0, "NORMAL:-VERS-SSL3.0", NULL, 0,
- &relay_config_check_network_ssl_priorities, NULL, NULL,
- &relay_config_change_network_ssl_priorities, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_totp_secret = weechat_config_new_option (
- relay_config_file, ptr_section,
- "totp_secret", "string",
- N_("secret for the generation of the Time-based One-Time Password "
- "(TOTP), encoded in base32 (only letters and digits from 2 to 7); "
- "it is used as second factor in weechat protocol, in addition to "
- "the password, which must not be empty "
- "(empty value means no TOTP is required) "
- "(note: content is evaluated, see /help eval)"),
- NULL, 0, 0, "", NULL, 0,
- &relay_config_check_network_totp_secret, NULL, NULL,
NULL, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_network_totp_window = weechat_config_new_option (
- relay_config_file, ptr_section,
- "totp_window", "integer",
- N_("number of Time-based One-Time Passwords to accept before and "
- "after the current one: "
- "0 = accept only the current password, "
- "1 = accept one password before, the current, and one after, "
- "2 = accept two passwords before, the current, and two after, "
- "...; a high number reduces the security level "
- "(0 or 1 are recommended values)"),
- NULL, 0, 256, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_network_websocket_allowed_origins = weechat_config_new_option (
- relay_config_file, ptr_section,
- "websocket_allowed_origins", "string",
- N_("POSIX extended regular expression with origins allowed in "
- "websockets (case insensitive, use \"(?-i)\" at beginning to make "
- "it case sensitive), example: "
- "\"^https?://(www\\.)?example\\.(com|org)\""),
- NULL, 0, 0, "", NULL, 0,
NULL, NULL, NULL,
- &relay_config_change_network_websocket_allowed_origins, NULL, NULL,
NULL, NULL, NULL);
-
- /* section irc */
- ptr_section = weechat_config_new_section (relay_config_file, "irc",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (relay_config_section_irc)
{
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
+ relay_config_irc_backlog_max_minutes = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_max_minutes", "integer",
+ N_("maximum number of minutes in backlog per IRC channel "
+ "(0 = unlimited, examples: 1440 = one day, 10080 = one week, "
+ "43200 = one month, 525600 = one year)"),
+ NULL, 0, INT_MAX, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_irc_backlog_max_number = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_max_number", "integer",
+ N_("maximum number of lines in backlog per IRC channel "
+ "(0 = unlimited)"),
+ NULL, 0, INT_MAX, "1024", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_irc_backlog_since_last_disconnect = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_since_last_disconnect", "boolean",
+ N_("display backlog starting from last client disconnect"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_irc_backlog_since_last_message = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_since_last_message", "boolean",
+ N_("display backlog starting from your last message"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ relay_config_irc_backlog_tags = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_tags", "string",
+ N_("comma-separated list of messages tags which are displayed in "
+ "backlog per IRC channel (supported tags: \"irc_join\", "
+ "\"irc_part\", \"irc_quit\", \"irc_nick\", \"irc_privmsg\"), "
+ "\"*\" = all supported tags"),
+ NULL, 0, 0, "irc_privmsg", NULL, 0,
+ &relay_config_check_irc_backlog_tags, NULL, NULL,
+ &relay_config_change_irc_backlog_tags, NULL, NULL,
+ NULL, NULL, NULL);
+ relay_config_irc_backlog_time_format = weechat_config_new_option (
+ relay_config_file, relay_config_section_irc,
+ "backlog_time_format", "string",
+ N_("format for time in backlog messages (see man strftime for "
+ "format) (not used if server capability \"server-time\" was "
+ "enabled by client, because time is sent as irc tag); empty "
+ "string = disable time in backlog messages"),
+ NULL, 0, 0, "[%H:%M] ", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- relay_config_irc_backlog_max_minutes = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_max_minutes", "integer",
- N_("maximum number of minutes in backlog per IRC channel "
- "(0 = unlimited, examples: 1440 = one day, 10080 = one week, "
- "43200 = one month, 525600 = one year)"),
- NULL, 0, INT_MAX, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_irc_backlog_max_number = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_max_number", "integer",
- N_("maximum number of lines in backlog per IRC channel "
- "(0 = unlimited)"),
- NULL, 0, INT_MAX, "1024", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_irc_backlog_since_last_disconnect = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_since_last_disconnect", "boolean",
- N_("display backlog starting from last client disconnect"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_irc_backlog_since_last_message = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_since_last_message", "boolean",
- N_("display backlog starting from your last message"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- relay_config_irc_backlog_tags = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_tags", "string",
- N_("comma-separated list of messages tags which are displayed in "
- "backlog per IRC channel (supported tags: \"irc_join\", "
- "\"irc_part\", \"irc_quit\", \"irc_nick\", \"irc_privmsg\"), "
- "\"*\" = all supported tags"),
- NULL, 0, 0, "irc_privmsg", NULL, 0,
- &relay_config_check_irc_backlog_tags, NULL, NULL,
- &relay_config_change_irc_backlog_tags, NULL, NULL,
- NULL, NULL, NULL);
- relay_config_irc_backlog_time_format = weechat_config_new_option (
- relay_config_file, ptr_section,
- "backlog_time_format", "string",
- N_("format for time in backlog messages (see man strftime for format) "
- "(not used if server capability \"server-time\" was enabled by "
- "client, because time is sent as irc tag); empty string = disable "
- "time in backlog messages"),
- NULL, 0, 0, "[%H:%M] ", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* section weechat */
- ptr_section = weechat_config_new_section (relay_config_file, "weechat",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
- }
-
- relay_config_weechat_commands = weechat_config_new_option (
- relay_config_file, ptr_section,
- "commands", "string",
- N_("comma-separated list of commands allowed/denied when input "
- "data (text or command) is received from a client; "
- "\"*\" means any command, a name beginning with \"!\" is "
- "a negative value to prevent a command from being executed, "
- "wildcard \"*\" is allowed in names; this option should be set if "
- "the relay client is not safe (someone could use it to run "
- "commands); for example \"*,!exec,!quit\" allows any command "
- "except /exec and /quit"),
- NULL, 0, 0, "", NULL, 0,
+ relay_config_section_weechat = weechat_config_new_section (
+ relay_config_file, "weechat",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
+ if (relay_config_section_weechat)
+ {
+ relay_config_weechat_commands = weechat_config_new_option (
+ relay_config_file, relay_config_section_weechat,
+ "commands", "string",
+ N_("comma-separated list of commands allowed/denied when input "
+ "data (text or command) is received from a client; "
+ "\"*\" means any command, a name beginning with \"!\" is "
+ "a negative value to prevent a command from being executed, "
+ "wildcard \"*\" is allowed in names; this option should be set "
+ "if the relay client is not safe (someone could use it to run "
+ "commands); for example \"*,!exec,!quit\" allows any command "
+ "except /exec and /quit"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ }
/* section port */
- ptr_section = weechat_config_new_section (
+ relay_config_section_port = weechat_config_new_section (
relay_config_file, "port",
1, 1,
NULL, NULL, NULL,
@@ -1301,17 +1296,9 @@ relay_config_init ()
NULL, NULL, NULL,
&relay_config_create_option_port_path, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
- }
-
- relay_config_section_port = ptr_section;
/* section path */
- ptr_section = weechat_config_new_section (
+ relay_config_section_path = weechat_config_new_section (
relay_config_file, "path",
1, 1,
NULL, NULL, NULL,
@@ -1319,14 +1306,6 @@ relay_config_init ()
NULL, NULL, NULL,
&relay_config_create_option_port_path, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (relay_config_file);
- relay_config_file = NULL;
- return 0;
- }
-
- relay_config_section_path = ptr_section;
return 1;
}
diff --git a/src/plugins/script/script-config.c b/src/plugins/script/script-config.c
index ea9e9290f..cf7c16961 100644
--- a/src/plugins/script/script-config.c
+++ b/src/plugins/script/script-config.c
@@ -35,55 +35,61 @@
struct t_config_file *script_config_file = NULL;
+/* sections */
+
+struct t_config_section *script_config_section_look = NULL;
+struct t_config_section *script_config_section_color = NULL;
+struct t_config_section *script_config_section_scripts = NULL;
+
/* script config, look section */
-struct t_config_option *script_config_look_columns;
-struct t_config_option *script_config_look_diff_color;
-struct t_config_option *script_config_look_diff_command;
-struct t_config_option *script_config_look_display_source;
-struct t_config_option *script_config_look_quiet_actions;
-struct t_config_option *script_config_look_sort;
-struct t_config_option *script_config_look_translate_description;
-struct t_config_option *script_config_look_use_keys;
+struct t_config_option *script_config_look_columns = NULL;
+struct t_config_option *script_config_look_diff_color = NULL;
+struct t_config_option *script_config_look_diff_command = NULL;
+struct t_config_option *script_config_look_display_source = NULL;
+struct t_config_option *script_config_look_quiet_actions = NULL;
+struct t_config_option *script_config_look_sort = NULL;
+struct t_config_option *script_config_look_translate_description = NULL;
+struct t_config_option *script_config_look_use_keys = NULL;
/* script config, color section */
-struct t_config_option *script_config_color_status_autoloaded;
-struct t_config_option *script_config_color_status_held;
-struct t_config_option *script_config_color_status_installed;
-struct t_config_option *script_config_color_status_obsolete;
-struct t_config_option *script_config_color_status_popular;
-struct t_config_option *script_config_color_status_running;
-struct t_config_option *script_config_color_status_unknown;
-struct t_config_option *script_config_color_text;
-struct t_config_option *script_config_color_text_bg;
-struct t_config_option *script_config_color_text_bg_selected;
-struct t_config_option *script_config_color_text_date;
-struct t_config_option *script_config_color_text_date_selected;
-struct t_config_option *script_config_color_text_delimiters;
-struct t_config_option *script_config_color_text_description;
-struct t_config_option *script_config_color_text_description_selected;
-struct t_config_option *script_config_color_text_extension;
-struct t_config_option *script_config_color_text_extension_selected;
-struct t_config_option *script_config_color_text_name;
-struct t_config_option *script_config_color_text_name_selected;
-struct t_config_option *script_config_color_text_selected;
-struct t_config_option *script_config_color_text_tags;
-struct t_config_option *script_config_color_text_tags_selected;
-struct t_config_option *script_config_color_text_version;
-struct t_config_option *script_config_color_text_version_loaded;
-struct t_config_option *script_config_color_text_version_loaded_selected;
-struct t_config_option *script_config_color_text_version_selected;
+struct t_config_option *script_config_color_status_autoloaded = NULL;
+struct t_config_option *script_config_color_status_held = NULL;
+struct t_config_option *script_config_color_status_installed = NULL;
+struct t_config_option *script_config_color_status_obsolete = NULL;
+struct t_config_option *script_config_color_status_popular = NULL;
+struct t_config_option *script_config_color_status_running = NULL;
+struct t_config_option *script_config_color_status_unknown = NULL;
+struct t_config_option *script_config_color_text = NULL;
+struct t_config_option *script_config_color_text_bg = NULL;
+struct t_config_option *script_config_color_text_bg_selected = NULL;
+struct t_config_option *script_config_color_text_date = NULL;
+struct t_config_option *script_config_color_text_date_selected = NULL;
+struct t_config_option *script_config_color_text_delimiters = NULL;
+struct t_config_option *script_config_color_text_description = NULL;
+struct t_config_option *script_config_color_text_description_selected = NULL;
+struct t_config_option *script_config_color_text_extension = NULL;
+struct t_config_option *script_config_color_text_extension_selected = NULL;
+struct t_config_option *script_config_color_text_name = NULL;
+struct t_config_option *script_config_color_text_name_selected = NULL;
+struct t_config_option *script_config_color_text_selected = NULL;
+struct t_config_option *script_config_color_text_tags = NULL;
+struct t_config_option *script_config_color_text_tags_selected = NULL;
+struct t_config_option *script_config_color_text_version = NULL;
+struct t_config_option *script_config_color_text_version_loaded = NULL;
+struct t_config_option *script_config_color_text_version_loaded_selected = NULL;
+struct t_config_option *script_config_color_text_version_selected = NULL;
/* script config, scripts section */
-struct t_config_option *script_config_scripts_autoload;
-struct t_config_option *script_config_scripts_cache_expire;
-struct t_config_option *script_config_scripts_download_enabled;
-struct t_config_option *script_config_scripts_download_timeout;
-struct t_config_option *script_config_scripts_hold;
-struct t_config_option *script_config_scripts_path;
-struct t_config_option *script_config_scripts_url;
+struct t_config_option *script_config_scripts_autoload = NULL;
+struct t_config_option *script_config_scripts_cache_expire = NULL;
+struct t_config_option *script_config_scripts_download_enabled = NULL;
+struct t_config_option *script_config_scripts_download_timeout = NULL;
+struct t_config_option *script_config_scripts_hold = NULL;
+struct t_config_option *script_config_scripts_path = NULL;
+struct t_config_option *script_config_scripts_url = NULL;
/*
@@ -418,8 +424,6 @@ script_config_reload (const void *pointer, void *data,
int
script_config_init ()
{
- struct t_config_section *ptr_section;
-
script_config_file = weechat_config_new (
SCRIPT_CONFIG_PRIO_NAME,
&script_config_reload, NULL, NULL);
@@ -427,392 +431,384 @@ script_config_init ()
return 0;
/* look */
- ptr_section = weechat_config_new_section (script_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (script_config_file);
- script_config_file = NULL;
- return 0;
- }
-
- script_config_look_columns = weechat_config_new_option (
- script_config_file, ptr_section,
- "columns", "string",
- N_("format of columns displayed in script buffer: following column "
- "identifiers are replaced by their values: %a=author, %d=description, "
- "%D=date added, %e=extension, %l=language, %L=license, %n=name with "
- "extension, %N=name, %r=requirements, %s=status, %t=tags, "
- "%u=date updated, %v=version, %V=version loaded, %w=min_weechat, "
- "%W=max_weechat)"),
- NULL, 0, 0, "%s %n %V %v %u | %d | %t", NULL, 0,
+ script_config_section_look = weechat_config_new_section (
+ script_config_file, "look",
+ 0, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_look_diff_color = weechat_config_new_option (
- script_config_file, ptr_section,
- "diff_color", "boolean",
- N_("colorize output of diff"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_look_diff_command = weechat_config_new_option (
- script_config_file, ptr_section,
- "diff_command", "string",
- N_("command used to show differences between script installed and the "
- "new version in repository (\"auto\" = auto detect diff command (git "
- "or diff), empty value = disable diff, other string = name of "
- "command, for example \"diff\")"),
- NULL, 0, 0, "auto", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_look_display_source = weechat_config_new_option (
- script_config_file, ptr_section,
- "display_source", "boolean",
- N_("display source code of script on buffer with detail on a script "
- "(script is downloaded in a temporary file when detail on script "
- "is displayed)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_look_quiet_actions = weechat_config_new_option (
- script_config_file, ptr_section,
- "quiet_actions", "boolean",
- N_("quiet actions on script buffer: do not display messages on core "
- "buffer when scripts are installed/removed/loaded/unloaded (only "
- "errors are displayed)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_look_sort = weechat_config_new_option (
- script_config_file, ptr_section,
- "sort", "string",
- N_("default sort keys for scripts: comma-separated list of identifiers: "
- "a=author, A=autoloaded, d=date added, e=extension, i=installed, "
- "l=language, n=name, o=obsolete, p=popularity, r=running, "
- "u=date updated; char \"-\" can be used before identifier to reverse "
- "order; example: \"i,u\": installed scripts first, sorted by update "
- "date"),
- NULL, 0, 0, "i,p,n", NULL, 0,
NULL, NULL, NULL,
- &script_config_reload_scripts_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_look_translate_description = weechat_config_new_option (
- script_config_file, ptr_section,
- "translate_description", "boolean",
- N_("translate description of scripts (if translation is available in "
- "your language, otherwise English version is used)"),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
- &script_config_reload_scripts_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_look_use_keys = weechat_config_new_option (
- script_config_file, ptr_section,
- "use_keys", "boolean",
- N_("use keys alt+X in script buffer to do actions on scripts (alt+i = "
- "install, alt+r = remove, ...); if disabled, only the input is "
- "allowed: i, r, ..."),
- NULL, 0, 0, "on", NULL, 0,
NULL, NULL, NULL,
- &script_config_change_use_keys_cb, NULL, NULL,
NULL, NULL, NULL);
-
- /* color */
- ptr_section = weechat_config_new_section (script_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (script_config_section_look)
{
- weechat_config_free (script_config_file);
- script_config_file = NULL;
- return 0;
+ script_config_look_columns = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "columns", "string",
+ N_("format of columns displayed in script buffer: following column "
+ "identifiers are replaced by their values: %a=author, "
+ "%d=description, %D=date added, %e=extension, %l=language, "
+ "%L=license, %n=name with extension, %N=name, %r=requirements, "
+ "%s=status, %t=tags, %u=date updated, %v=version, "
+ "%V=version loaded, %w=min_weechat, %W=max_weechat)"),
+ NULL, 0, 0, "%s %n %V %v %u | %d | %t", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_look_diff_color = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "diff_color", "boolean",
+ N_("colorize output of diff"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_look_diff_command = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "diff_command", "string",
+ N_("command used to show differences between script installed and "
+ "the new version in repository (\"auto\" = auto detect diff "
+ "command (git or diff), empty value = disable diff, other "
+ "string = name of command, for example \"diff\")"),
+ NULL, 0, 0, "auto", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_look_display_source = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "display_source", "boolean",
+ N_("display source code of script on buffer with detail on a script "
+ "(script is downloaded in a temporary file when detail on script "
+ "is displayed)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_look_quiet_actions = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "quiet_actions", "boolean",
+ N_("quiet actions on script buffer: do not display messages on core "
+ "buffer when scripts are installed/removed/loaded/unloaded (only "
+ "errors are displayed)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_look_sort = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "sort", "string",
+ N_("default sort keys for scripts: comma-separated list of "
+ "identifiers: a=author, A=autoloaded, d=date added, e=extension, "
+ "i=installed, l=language, n=name, o=obsolete, p=popularity, "
+ "r=running, u=date updated; char \"-\" can be used before "
+ "identifier to reverse order; example: \"i,u\": installed "
+ "scripts first, sorted by update date"),
+ NULL, 0, 0, "i,p,n", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_reload_scripts_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_look_translate_description = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "translate_description", "boolean",
+ N_("translate description of scripts (if translation is available "
+ "in your language, otherwise English version is used)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_reload_scripts_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_look_use_keys = weechat_config_new_option (
+ script_config_file, script_config_section_look,
+ "use_keys", "boolean",
+ N_("use keys alt+X in script buffer to do actions on scripts "
+ "(alt+i = install, alt+r = remove, ...); if disabled, only the "
+ "input is allowed: i, r, ..."),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_change_use_keys_cb, NULL, NULL,
+ NULL, NULL, NULL);
}
- script_config_color_status_autoloaded = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_autoloaded", "color",
- N_("color for status \"autoloaded\" (\"a\")"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_held = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_held", "color",
- N_("color for status \"held\" (\"H\")"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_installed = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_installed", "color",
- N_("color for status \"installed\" (\"i\")"),
- NULL, 0, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_obsolete = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_obsolete", "color",
- N_("color for status \"obsolete\" (\"N\")"),
- NULL, 0, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_popular = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_popular", "color",
- N_("color for status \"popular\" (\"*\")"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_running = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_running", "color",
- N_("color for status \"running\" (\"r\")"),
- NULL, 0, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_status_unknown = weechat_config_new_option (
- script_config_file, ptr_section,
- "status_unknown", "color",
- N_("color for status \"unknown\" (\"?\")"),
- NULL, 0, 0, "lightred", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text = weechat_config_new_option (
- script_config_file, ptr_section,
- "text", "color",
- N_("text color in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_bg = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_bg", "color",
- N_("background color in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_bg_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_bg_selected", "color",
- N_("background color for selected line in script buffer"),
- NULL, 0, 0, "red", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_date = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_date", "color",
- N_("text color of dates in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_date_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_date_selected", "color",
- N_("text color of dates for selected line in script buffer"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_delimiters = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_delimiters", "color",
- N_("text color of delimiters in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_description = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_description", "color",
- N_("text color of description in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_description_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_description_selected", "color",
- N_("text color of description for selected line in script buffer"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_extension = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_extension", "color",
- N_("text color of extension in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_extension_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_extension_selected", "color",
- N_("text color of extension for selected line in script buffer"),
- NULL, 0, 0, "white", NULL, 0,
+ /* color */
+ script_config_section_color = weechat_config_new_section (
+ script_config_file, "color",
+ 0, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_name = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_name", "color",
- N_("text color of script name in script buffer"),
- NULL, 0, 0, "cyan", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_name_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_name_selected", "color",
- N_("text color of script name for selected line in script buffer"),
- NULL, 0, 0, "lightcyan", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_selected", "color",
- N_("text color for selected line in script buffer"),
- NULL, 0, 0, "white", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
- script_config_color_text_tags = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_tags", "color",
- N_("text color of tags in script buffer"),
- NULL, 0, 0, "brown", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_tags_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_tags_selected", "color",
- N_("text color of tags for selected line in script buffer"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_version = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_version", "color",
- N_("text color of version in script buffer"),
- NULL, 0, 0, "magenta", NULL, 0,
+ if (script_config_section_color)
+ {
+ script_config_color_status_autoloaded = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_autoloaded", "color",
+ N_("color for status \"autoloaded\" (\"a\")"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_held = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_held", "color",
+ N_("color for status \"held\" (\"H\")"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_installed = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_installed", "color",
+ N_("color for status \"installed\" (\"i\")"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_obsolete = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_obsolete", "color",
+ N_("color for status \"obsolete\" (\"N\")"),
+ NULL, 0, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_popular = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_popular", "color",
+ N_("color for status \"popular\" (\"*\")"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_running = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_running", "color",
+ N_("color for status \"running\" (\"r\")"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_status_unknown = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "status_unknown", "color",
+ N_("color for status \"unknown\" (\"?\")"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text", "color",
+ N_("text color in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_bg = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_bg", "color",
+ N_("background color in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_bg_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_bg_selected", "color",
+ N_("background color for selected line in script buffer"),
+ NULL, 0, 0, "red", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_date = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_date", "color",
+ N_("text color of dates in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_date_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_date_selected", "color",
+ N_("text color of dates for selected line in script buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_delimiters = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_delimiters", "color",
+ N_("text color of delimiters in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_description = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_description", "color",
+ N_("text color of description in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_description_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_description_selected", "color",
+ N_("text color of description for selected line in script buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_extension = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_extension", "color",
+ N_("text color of extension in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_extension_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_extension_selected", "color",
+ N_("text color of extension for selected line in script buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_name = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_name", "color",
+ N_("text color of script name in script buffer"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_name_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_name_selected", "color",
+ N_("text color of script name for selected line in script buffer"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_selected", "color",
+ N_("text color for selected line in script buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_tags = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_tags", "color",
+ N_("text color of tags in script buffer"),
+ NULL, 0, 0, "brown", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_tags_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_tags_selected", "color",
+ N_("text color of tags for selected line in script buffer"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_version = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_version", "color",
+ N_("text color of version in script buffer"),
+ NULL, 0, 0, "magenta", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_version_loaded = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_version_loaded", "color",
+ N_("text color of version loaded in script buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_version_loaded_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_version_loaded_selected", "color",
+ N_("text color of version loaded for selected line in script buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_color_text_version_selected = weechat_config_new_option (
+ script_config_file, script_config_section_color,
+ "text_version_selected", "color",
+ N_("text color of version for selected line in script buffer"),
+ NULL, 0, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ }
+
+ /* scripts */
+ script_config_section_scripts = weechat_config_new_section (
+ script_config_file, "scripts",
+ 0, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_version_loaded = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_version_loaded", "color",
- N_("text color of version loaded in script buffer"),
- NULL, 0, 0, "default", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_version_loaded_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_version_loaded_selected", "color",
- N_("text color of version loaded for selected line in script buffer"),
- NULL, 0, 0, "white", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_color_text_version_selected = weechat_config_new_option (
- script_config_file, ptr_section,
- "text_version_selected", "color",
- N_("text color of version for selected line in script buffer"),
- NULL, 0, 0, "lightmagenta", NULL, 0,
NULL, NULL, NULL,
- &script_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
-
- /* scripts */
- ptr_section = weechat_config_new_section (script_config_file, "scripts",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (script_config_section_scripts)
{
- weechat_config_free (script_config_file);
- script_config_file = NULL;
- return 0;
+ script_config_scripts_autoload = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "autoload", "boolean",
+ N_("autoload scripts installed (make a link in \"autoload\" directory "
+ "to script in parent directory)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_scripts_cache_expire = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "cache_expire", "integer",
+ N_("local cache expiration time, in minutes (-1 = never expires, "
+ "0 = always expire)"),
+ NULL, -1, 525600, "1440", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_scripts_download_enabled = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "download_enabled", "boolean",
+ N_("enable download of files from the scripts repository when the "
+ "/script command is used (list of scripts and scripts "
+ "themselves); the list of scripts is downloaded from the URL "
+ "specified in the option script.scripts.url; WeeChat will "
+ "sometimes download again the list of scripts when you use the "
+ "/script command, even if you don't install a script"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_scripts_download_timeout = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "download_timeout", "integer",
+ N_("timeout (in seconds) for download of scripts and list of "
+ "scripts"),
+ NULL, 1, 3600, "30", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_scripts_hold = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "hold", "string",
+ N_("scripts to \"hold\": comma-separated list of scripts which "
+ "will never been upgraded and can not be removed, for example: "
+ "\"go.py,urlserver.py\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &script_config_change_hold_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ script_config_scripts_path = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "path", "string",
+ N_("local cache directory for scripts "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_cache_dir}/script", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ script_config_scripts_url = weechat_config_new_option (
+ script_config_file, script_config_section_scripts,
+ "url", "string",
+ N_("URL for file with list of scripts"),
+ NULL, 0, 0, "https://weechat.org/files/plugins.xml.gz", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- script_config_scripts_autoload = weechat_config_new_option (
- script_config_file, ptr_section,
- "autoload", "boolean",
- N_("autoload scripts installed (make a link in \"autoload\" directory "
- "to script in parent directory)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_scripts_cache_expire = weechat_config_new_option (
- script_config_file, ptr_section,
- "cache_expire", "integer",
- N_("local cache expiration time, in minutes (-1 = never expires, "
- "0 = always expire)"),
- NULL, -1, 525600, "1440", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_scripts_download_enabled = weechat_config_new_option (
- script_config_file, ptr_section,
- "download_enabled", "boolean",
- N_("enable download of files from the scripts repository when the "
- "/script command is used (list of scripts and scripts themselves); "
- "the list of scripts is downloaded from the URL specified in the "
- "option script.scripts.url; WeeChat will sometimes download again "
- "the list of scripts when you use the /script command, even if "
- "you don't install a script"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_scripts_download_timeout = weechat_config_new_option (
- script_config_file, ptr_section,
- "download_timeout", "integer",
- N_("timeout (in seconds) for download of scripts and list of scripts"),
- NULL, 1, 3600, "30", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_scripts_hold = weechat_config_new_option (
- script_config_file, ptr_section,
- "hold", "string",
- N_("scripts to \"hold\": comma-separated list of scripts which will "
- "never been upgraded and can not be removed, for example: "
- "\"go.py,urlserver.py\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &script_config_change_hold_cb, NULL, NULL,
- NULL, NULL, NULL);
- script_config_scripts_path = weechat_config_new_option (
- script_config_file, ptr_section,
- "path", "string",
- N_("local cache directory for scripts "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_cache_dir}/script", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- script_config_scripts_url = weechat_config_new_option (
- script_config_file, ptr_section,
- "url", "string",
- N_("URL for file with list of scripts"),
- NULL, 0, 0, "https://weechat.org/files/plugins.xml.gz", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
return 1;
}
diff --git a/src/plugins/spell/spell-config.c b/src/plugins/spell/spell-config.c
index c31ef3bf7..9bab0dfcb 100644
--- a/src/plugins/spell/spell-config.c
+++ b/src/plugins/spell/spell-config.c
@@ -31,33 +31,39 @@
struct t_config_file *spell_config_file = NULL;
-struct t_config_section *spell_config_section_dict = NULL;
-int spell_config_loading = 0;
+/* sections */
+
+struct t_config_section *spell_config_section_color = NULL;
+struct t_config_section *spell_config_section_check = NULL;
+struct t_config_section *spell_config_section_dict = NULL;
+struct t_config_section *spell_config_section_look = NULL;
+struct t_config_section *spell_config_section_option = NULL;
/* spell config, color section */
-struct t_config_option *spell_config_color_misspelled;
-struct t_config_option *spell_config_color_suggestion;
-struct t_config_option *spell_config_color_suggestion_delimiter_dict;
-struct t_config_option *spell_config_color_suggestion_delimiter_word;
+struct t_config_option *spell_config_color_misspelled = NULL;
+struct t_config_option *spell_config_color_suggestion = NULL;
+struct t_config_option *spell_config_color_suggestion_delimiter_dict = NULL;
+struct t_config_option *spell_config_color_suggestion_delimiter_word = NULL;
/* spell config, check section */
-struct t_config_option *spell_config_check_commands;
-struct t_config_option *spell_config_check_default_dict;
-struct t_config_option *spell_config_check_during_search;
-struct t_config_option *spell_config_check_enabled;
-struct t_config_option *spell_config_check_real_time;
-struct t_config_option *spell_config_check_suggestions;
-struct t_config_option *spell_config_check_word_min_length;
+struct t_config_option *spell_config_check_commands = NULL;
+struct t_config_option *spell_config_check_default_dict = NULL;
+struct t_config_option *spell_config_check_during_search = NULL;
+struct t_config_option *spell_config_check_enabled = NULL;
+struct t_config_option *spell_config_check_real_time = NULL;
+struct t_config_option *spell_config_check_suggestions = NULL;
+struct t_config_option *spell_config_check_word_min_length = NULL;
/* spell config, look section */
-struct t_config_option *spell_config_look_suggestion_delimiter_dict;
-struct t_config_option *spell_config_look_suggestion_delimiter_word;
+struct t_config_option *spell_config_look_suggestion_delimiter_dict = NULL;
+struct t_config_option *spell_config_look_suggestion_delimiter_word = NULL;
+int spell_config_loading = 0;
char **spell_commands_to_check = NULL;
int spell_count_commands_to_check = 0;
int *spell_length_commands_to_check = NULL;
@@ -439,15 +445,13 @@ spell_config_set_dict (const char *name, const char *value)
int
spell_config_init ()
{
- struct t_config_section *ptr_section;
-
spell_config_file = weechat_config_new (SPELL_CONFIG_PRIO_NAME,
NULL, NULL, NULL);
if (!spell_config_file)
return 0;
/* color */
- ptr_section = weechat_config_new_section (
+ spell_config_section_color = weechat_config_new_section (
spell_config_file, "color",
0, 0,
NULL, NULL, NULL,
@@ -455,43 +459,39 @@ spell_config_init ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
+ if (spell_config_section_color)
{
- weechat_config_free (spell_config_file);
- spell_config_file = NULL;
- return 0;
+ spell_config_color_misspelled = weechat_config_new_option (
+ spell_config_file, spell_config_section_color,
+ "misspelled", "color",
+ N_("text color for misspelled words (input bar)"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ spell_config_color_suggestion = weechat_config_new_option (
+ spell_config_file, spell_config_section_color,
+ "suggestion", "color",
+ N_("text color for suggestion on a misspelled word in bar item "
+ "\"spell_suggest\""),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ spell_config_color_suggestion_delimiter_dict = weechat_config_new_option (
+ spell_config_file, spell_config_section_color,
+ "suggestion_delimiter_dict", "color",
+ N_("text color for delimiters displayed between two dictionaries "
+ "in bar item \"spell_suggest\""),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ spell_config_color_suggestion_delimiter_word = weechat_config_new_option (
+ spell_config_file, spell_config_section_color,
+ "suggestion_delimiter_word", "color",
+ N_("text color for delimiters displayed between two words in bar "
+ "item \"spell_suggest\""),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- spell_config_color_misspelled = weechat_config_new_option (
- spell_config_file, ptr_section,
- "misspelled", "color",
- N_("text color for misspelled words (input bar)"),
- NULL, 0, 0, "lightred", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- spell_config_color_suggestion = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestion", "color",
- N_("text color for suggestion on a misspelled word in bar item "
- "\"spell_suggest\""),
- NULL, 0, 0, "default", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- spell_config_color_suggestion_delimiter_dict = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestion_delimiter_dict", "color",
- N_("text color for delimiters displayed between two dictionaries "
- "in bar item \"spell_suggest\""),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- spell_config_color_suggestion_delimiter_word = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestion_delimiter_word", "color",
- N_("text color for delimiters displayed between two words in bar item "
- "\"spell_suggest\""),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* check */
- ptr_section = weechat_config_new_section (
+ spell_config_section_check = weechat_config_new_section (
spell_config_file, "check",
0, 0,
NULL, NULL, NULL,
@@ -499,76 +499,72 @@ spell_config_init ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
+ if (spell_config_section_check)
{
- weechat_config_free (spell_config_file);
- spell_config_file = NULL;
- return 0;
+ spell_config_check_commands = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "commands", "string",
+ N_("comma separated list of commands for which spell checking is "
+ "enabled (spell checking is disabled for all other commands)"),
+ NULL, 0, 0,
+ "away,command,cycle,kick,kickban,me,msg,notice,part,query,"
+ "quit,topic", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_commands, NULL, NULL,
+ NULL, NULL, NULL);
+ spell_config_check_default_dict = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "default_dict", "string",
+ N_("default dictionary (or comma separated list of dictionaries) to "
+ "use when buffer has no dictionary defined (leave blank to "
+ "disable spell checker on buffers for which you didn't "
+ "explicitly enabled it)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_default_dict, NULL, NULL,
+ NULL, NULL, NULL);
+ spell_config_check_during_search = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "during_search", "boolean",
+ N_("check words during text search in buffer"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ spell_config_check_enabled = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "enabled", "boolean",
+ N_("enable spell checker for command line"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ spell_config_check_real_time = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "real_time", "boolean",
+ N_("real-time spell checking of words (slower, disabled by default: "
+ "words are checked only if there's delimiter after)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ spell_config_check_suggestions = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "suggestions", "integer",
+ N_("number of suggestions to display in bar item \"spell_suggest\" "
+ "for each dictionary set in buffer (-1 = disable suggestions, "
+ "0 = display all possible suggestions in all languages)"),
+ NULL, -1, INT_MAX, "-1", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_suggestions, NULL, NULL,
+ NULL, NULL, NULL);
+ spell_config_check_word_min_length = weechat_config_new_option (
+ spell_config_file, spell_config_section_check,
+ "word_min_length", "integer",
+ N_("minimum length for a word to be spell checked (use 0 to check "
+ "all words)"),
+ NULL, 0, INT_MAX, "2", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- spell_config_check_commands = weechat_config_new_option (
- spell_config_file, ptr_section,
- "commands", "string",
- N_("comma separated list of commands for which spell checking is "
- "enabled (spell checking is disabled for all other commands)"),
- NULL, 0, 0,
- "away,command,cycle,kick,kickban,me,msg,notice,part,query,"
- "quit,topic", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_commands, NULL, NULL,
- NULL, NULL, NULL);
- spell_config_check_default_dict = weechat_config_new_option (
- spell_config_file, ptr_section,
- "default_dict", "string",
- N_("default dictionary (or comma separated list of dictionaries) to "
- "use when buffer has no dictionary defined (leave blank to disable "
- "spell checker on buffers for which you didn't explicitly "
- "enabled it)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_default_dict, NULL, NULL,
- NULL, NULL, NULL);
- spell_config_check_during_search = weechat_config_new_option (
- spell_config_file, ptr_section,
- "during_search", "boolean",
- N_("check words during text search in buffer"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- spell_config_check_enabled = weechat_config_new_option (
- spell_config_file, ptr_section,
- "enabled", "boolean",
- N_("enable spell checker for command line"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_enabled, NULL, NULL,
- NULL, NULL, NULL);
- spell_config_check_real_time = weechat_config_new_option (
- spell_config_file, ptr_section,
- "real_time", "boolean",
- N_("real-time spell checking of words (slower, disabled by default: "
- "words are checked only if there's delimiter after)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- spell_config_check_suggestions = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestions", "integer",
- N_("number of suggestions to display in bar item \"spell_suggest\" "
- "for each dictionary set in buffer (-1 = disable suggestions, "
- "0 = display all possible suggestions in all languages)"),
- NULL, -1, INT_MAX, "-1", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_suggestions, NULL, NULL,
- NULL, NULL, NULL);
- spell_config_check_word_min_length = weechat_config_new_option (
- spell_config_file, ptr_section,
- "word_min_length", "integer",
- N_("minimum length for a word to be spell checked (use 0 to check all "
- "words)"),
- NULL, 0, INT_MAX, "2", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* dict */
- ptr_section = weechat_config_new_section (
+ spell_config_section_dict = weechat_config_new_section (
spell_config_file, "dict",
1, 1,
NULL, NULL, NULL,
@@ -576,17 +572,9 @@ spell_config_init ()
NULL, NULL, NULL,
&spell_config_dict_create_option, NULL, NULL,
&spell_config_dict_delete_option, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (spell_config_file);
- spell_config_file = NULL;
- return 0;
- }
-
- spell_config_section_dict = ptr_section;
/* look */
- ptr_section = weechat_config_new_section (
+ spell_config_section_look = weechat_config_new_section (
spell_config_file, "look",
0, 0,
NULL, NULL, NULL,
@@ -594,34 +582,30 @@ spell_config_init ()
NULL, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
+ if (spell_config_section_look)
{
- weechat_config_free (spell_config_file);
- spell_config_file = NULL;
- return 0;
+ spell_config_look_suggestion_delimiter_dict = weechat_config_new_option (
+ spell_config_file, spell_config_section_look,
+ "suggestion_delimiter_dict", "string",
+ N_("delimiter displayed between two dictionaries in bar item "
+ "\"spell_suggest\""),
+ NULL, 0, 0, " / ", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_suggestions, NULL, NULL,
+ NULL, NULL, NULL);
+ spell_config_look_suggestion_delimiter_word = weechat_config_new_option (
+ spell_config_file, spell_config_section_look,
+ "suggestion_delimiter_word", "string",
+ N_("delimiter displayed between two words in bar item "
+ "\"spell_suggest\""),
+ NULL, 0, 0, ",", NULL, 0,
+ NULL, NULL, NULL,
+ &spell_config_change_suggestions, NULL, NULL,
+ NULL, NULL, NULL);
}
- spell_config_look_suggestion_delimiter_dict = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestion_delimiter_dict", "string",
- N_("delimiter displayed between two dictionaries in bar item "
- "\"spell_suggest\""),
- NULL, 0, 0, " / ", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_suggestions, NULL, NULL,
- NULL, NULL, NULL);
- spell_config_look_suggestion_delimiter_word = weechat_config_new_option (
- spell_config_file, ptr_section,
- "suggestion_delimiter_word", "string",
- N_("delimiter displayed between two words in bar item "
- "\"spell_suggest\""),
- NULL, 0, 0, ",", NULL, 0,
- NULL, NULL, NULL,
- &spell_config_change_suggestions, NULL, NULL,
- NULL, NULL, NULL);
-
/* option */
- ptr_section = weechat_config_new_section (
+ spell_config_section_option = weechat_config_new_section (
spell_config_file, "option",
1, 1,
NULL, NULL, NULL,
@@ -629,12 +613,6 @@ spell_config_init ()
NULL, NULL, NULL,
&spell_config_option_create_option, NULL, NULL,
&spell_config_option_delete_option, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (spell_config_file);
- spell_config_file = NULL;
- return 0;
- }
return 1;
}
diff --git a/src/plugins/trigger/trigger-config.c b/src/plugins/trigger/trigger-config.c
index 001d7b958..ec25b0b3f 100644
--- a/src/plugins/trigger/trigger-config.c
+++ b/src/plugins/trigger/trigger-config.c
@@ -29,25 +29,30 @@
struct t_config_file *trigger_config_file = NULL;
+
+/* sections */
+
+struct t_config_section *trigger_config_section_look = NULL;
+struct t_config_section *trigger_config_section_color = NULL;
struct t_config_section *trigger_config_section_trigger = NULL;
/* trigger config, look section */
-struct t_config_option *trigger_config_look_enabled;
-struct t_config_option *trigger_config_look_monitor_strip_colors;
+struct t_config_option *trigger_config_look_enabled = NULL;
+struct t_config_option *trigger_config_look_monitor_strip_colors = NULL;
/* trigger config, color section */
-struct t_config_option *trigger_config_color_flag_command;
-struct t_config_option *trigger_config_color_flag_conditions;
-struct t_config_option *trigger_config_color_flag_regex;
-struct t_config_option *trigger_config_color_flag_return_code;
-struct t_config_option *trigger_config_color_flag_post_action;
-struct t_config_option *trigger_config_color_identifier;
-struct t_config_option *trigger_config_color_regex;
-struct t_config_option *trigger_config_color_replace;
-struct t_config_option *trigger_config_color_trigger;
-struct t_config_option *trigger_config_color_trigger_disabled;
+struct t_config_option *trigger_config_color_flag_command = NULL;
+struct t_config_option *trigger_config_color_flag_conditions = NULL;
+struct t_config_option *trigger_config_color_flag_regex = NULL;
+struct t_config_option *trigger_config_color_flag_return_code = NULL;
+struct t_config_option *trigger_config_color_flag_post_action = NULL;
+struct t_config_option *trigger_config_color_identifier = NULL;
+struct t_config_option *trigger_config_color_regex = NULL;
+struct t_config_option *trigger_config_color_replace = NULL;
+struct t_config_option *trigger_config_color_trigger = NULL;
+struct t_config_option *trigger_config_color_trigger_disabled = NULL;
char *trigger_config_default_list[][1 + TRIGGER_NUM_OPTIONS] =
{
@@ -683,8 +688,6 @@ trigger_config_reload_cb (const void *pointer, void *data,
int
trigger_config_init ()
{
- struct t_config_section *ptr_section;
-
trigger_config_file = weechat_config_new (
TRIGGER_CONFIG_PRIO_NAME,
&trigger_config_reload_cb, NULL, NULL);
@@ -692,113 +695,107 @@ trigger_config_init ()
return 0;
/* look */
- ptr_section = weechat_config_new_section (trigger_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ trigger_config_section_look = weechat_config_new_section (
+ trigger_config_file, "look",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ if (trigger_config_section_look)
{
- weechat_config_free (trigger_config_file);
- trigger_config_file = NULL;
- return 0;
+ trigger_config_look_enabled = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_look,
+ "enabled", "boolean",
+ N_("enable trigger support"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL,
+ &trigger_config_change_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ trigger_config_look_monitor_strip_colors = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_look,
+ "monitor_strip_colors", "boolean",
+ N_("strip colors in hashtable values displayed on monitor buffer"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- trigger_config_look_enabled = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "enabled", "boolean",
- N_("enable trigger support"),
- NULL, 0, 0, "on", NULL, 0,
+ /* color */
+ trigger_config_section_color = weechat_config_new_section (
+ trigger_config_file, "color",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &trigger_config_change_enabled, NULL, NULL,
NULL, NULL, NULL);
- trigger_config_look_monitor_strip_colors = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "monitor_strip_colors", "boolean",
- N_("strip colors in hashtable values displayed on monitor buffer"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- /* color */
- ptr_section = weechat_config_new_section (trigger_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (trigger_config_section_color)
{
- weechat_config_free (trigger_config_file);
- trigger_config_file = NULL;
- return 0;
+ trigger_config_color_flag_command = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "flag_command", "color",
+ N_("text color for command flag (in /trigger list)"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_flag_conditions = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "flag_conditions", "color",
+ N_("text color for conditions flag (in /trigger list)"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_flag_regex = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "flag_regex", "color",
+ N_("text color for regex flag (in /trigger list)"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_flag_return_code = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "flag_return_code", "color",
+ N_("text color for return code flag (in /trigger list)"),
+ NULL, 0, 0, "lightmagenta", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_flag_post_action = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "flag_post_action", "color",
+ N_("text color for post action flag (in /trigger list)"),
+ NULL, 0, 0, "lightblue", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_identifier = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "identifier", "color",
+ N_("text color for trigger context identifier in monitor buffer"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_regex = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "regex", "color",
+ N_("text color for regular expressions"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_replace = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "replace", "color",
+ N_("text color for replacement text (for regular expressions)"),
+ NULL, 0, 0, "cyan", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_trigger = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "trigger", "color",
+ N_("text color for trigger name"),
+ NULL, 0, 0, "green", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ trigger_config_color_trigger_disabled = weechat_config_new_option (
+ trigger_config_file, trigger_config_section_color,
+ "trigger_disabled", "color",
+ N_("text color for disabled trigger name"),
+ NULL, 0, 0, "red", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- trigger_config_color_flag_command = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "flag_command", "color",
- N_("text color for command flag (in /trigger list)"),
- NULL, 0, 0, "lightgreen", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_flag_conditions = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "flag_conditions", "color",
- N_("text color for conditions flag (in /trigger list)"),
- NULL, 0, 0, "yellow", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_flag_regex = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "flag_regex", "color",
- N_("text color for regex flag (in /trigger list)"),
- NULL, 0, 0, "lightcyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_flag_return_code = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "flag_return_code", "color",
- N_("text color for return code flag (in /trigger list)"),
- NULL, 0, 0, "lightmagenta", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_flag_post_action = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "flag_post_action", "color",
- N_("text color for post action flag (in /trigger list)"),
- NULL, 0, 0, "lightblue", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_identifier = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "identifier", "color",
- N_("text color for trigger context identifier in monitor buffer"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_regex = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "regex", "color",
- N_("text color for regular expressions"),
- NULL, 0, 0, "white", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_replace = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "replace", "color",
- N_("text color for replacement text (for regular expressions)"),
- NULL, 0, 0, "cyan", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_trigger = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "trigger", "color",
- N_("text color for trigger name"),
- NULL, 0, 0, "green", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- trigger_config_color_trigger_disabled = weechat_config_new_option (
- trigger_config_file, ptr_section,
- "trigger_disabled", "color",
- N_("text color for disabled trigger name"),
- NULL, 0, 0, "red", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
/* trigger */
- ptr_section = weechat_config_new_section (
+ trigger_config_section_trigger = weechat_config_new_section (
trigger_config_file,
TRIGGER_CONFIG_SECTION_TRIGGER,
0, 0,
@@ -807,14 +804,6 @@ trigger_config_init ()
&trigger_config_trigger_write_default_cb, NULL, NULL,
NULL, NULL, NULL,
NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (trigger_config_file);
- trigger_config_file = NULL;
- return 0;
- }
-
- trigger_config_section_trigger = ptr_section;
return 1;
}
diff --git a/src/plugins/trigger/trigger-config.h b/src/plugins/trigger/trigger-config.h
index f4653af1d..096ce9afb 100644
--- a/src/plugins/trigger/trigger-config.h
+++ b/src/plugins/trigger/trigger-config.h
@@ -25,6 +25,9 @@
#define TRIGGER_CONFIG_SECTION_TRIGGER "trigger"
extern struct t_config_file *trigger_config_file;
+
+extern struct t_config_section *trigger_config_section_look;
+extern struct t_config_section *trigger_config_section_color;
extern struct t_config_section *trigger_config_section_trigger;
extern struct t_config_option *trigger_config_look_enabled;
diff --git a/src/plugins/typing/typing-config.c b/src/plugins/typing/typing-config.c
index 04785e99a..6b2b79b98 100644
--- a/src/plugins/typing/typing-config.c
+++ b/src/plugins/typing/typing-config.c
@@ -31,18 +31,20 @@
struct t_config_file *typing_config_file = NULL;
-struct t_config_section *typing_config_section_cmd = NULL;
-struct t_config_section *typing_config_section_completion = NULL;
+
+/* sections */
+
+struct t_config_section *typing_config_section_look = NULL;
/* typing config, look section */
-struct t_config_option *typing_config_look_delay_purge_paused;
-struct t_config_option *typing_config_look_delay_purge_typing;
-struct t_config_option *typing_config_look_delay_set_paused;
-struct t_config_option *typing_config_look_enabled_nicks;
-struct t_config_option *typing_config_look_enabled_self;
-struct t_config_option *typing_config_look_input_min_chars;
-struct t_config_option *typing_config_look_item_max_length;
+struct t_config_option *typing_config_look_delay_purge_paused = NULL;
+struct t_config_option *typing_config_look_delay_purge_typing = NULL;
+struct t_config_option *typing_config_look_delay_set_paused = NULL;
+struct t_config_option *typing_config_look_enabled_nicks = NULL;
+struct t_config_option *typing_config_look_enabled_self = NULL;
+struct t_config_option *typing_config_look_input_min_chars = NULL;
+struct t_config_option *typing_config_look_item_max_length = NULL;
/*
@@ -110,8 +112,6 @@ typing_config_change_item_max_length (const void *pointer, void *data,
int
typing_config_init ()
{
- struct t_config_section *ptr_section;
-
typing_config_file = weechat_config_new (
TYPING_CONFIG_PRIO_NAME,
&typing_config_reload, NULL, NULL);
@@ -119,73 +119,73 @@ typing_config_init ()
return 0;
/* look */
- ptr_section = weechat_config_new_section (typing_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (typing_config_file);
- typing_config_file = NULL;
- return 0;
- }
-
- typing_config_look_delay_purge_paused = weechat_config_new_option (
- typing_config_file, ptr_section,
- "delay_purge_paused", "integer",
- N_("number of seconds after paused status has been set: if reached, "
- "the typing status is removed"),
- NULL, 1, INT_MAX, "30", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- typing_config_look_delay_purge_typing = weechat_config_new_option (
- typing_config_file, ptr_section,
- "delay_purge_typing", "integer",
- N_("number of seconds after typing status has been set: if reached, "
- "the typing status is removed"),
- NULL, 1, INT_MAX, "6", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- typing_config_look_delay_set_paused = weechat_config_new_option (
- typing_config_file, ptr_section,
- "delay_set_paused", "integer",
- N_("number of seconds after typing last char: if reached, the typing "
- "status becomes \"paused\" and no more typing signals are sent"),
- NULL, 1, INT_MAX, "10", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- typing_config_look_enabled_nicks = weechat_config_new_option (
- typing_config_file, ptr_section,
- "enabled_nicks", "boolean",
- N_("typing enabled for other nicks (display typing info for nicks "
- "typing in the current buffer)"),
- NULL, 0, 0, "off", NULL, 0,
+ typing_config_section_look = weechat_config_new_section (
+ typing_config_file, "look",
+ 0, 0,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &typing_config_change_enabled, NULL, NULL,
- NULL, NULL, NULL);
- typing_config_look_enabled_self = weechat_config_new_option (
- typing_config_file, ptr_section,
- "enabled_self", "boolean",
- N_("typing enabled for self messages (send typing info to other users)"),
- NULL, 0, 0, "off", NULL, 0,
NULL, NULL, NULL,
- &typing_config_change_enabled, NULL, NULL,
- NULL, NULL, NULL);
- typing_config_look_input_min_chars = weechat_config_new_option (
- typing_config_file, ptr_section,
- "input_min_chars", "integer",
- N_("min number of chars in message to trigger send of typing signals"),
- NULL, 1, INT_MAX, "4", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- typing_config_look_item_max_length = weechat_config_new_option (
- typing_config_file, ptr_section,
- "item_max_length", "integer",
- N_("max number of chars displayed in the bar item \"typing\" "
- "(0 = do not truncate content)"),
- NULL, 0, INT_MAX, "0", NULL, 0,
NULL, NULL, NULL,
- &typing_config_change_item_max_length, NULL, NULL,
NULL, NULL, NULL);
+ if (typing_config_section_look)
+ {
+ typing_config_look_delay_purge_paused = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "delay_purge_paused", "integer",
+ N_("number of seconds after paused status has been set: if reached, "
+ "the typing status is removed"),
+ NULL, 1, INT_MAX, "30", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ typing_config_look_delay_purge_typing = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "delay_purge_typing", "integer",
+ N_("number of seconds after typing status has been set: if reached, "
+ "the typing status is removed"),
+ NULL, 1, INT_MAX, "6", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ typing_config_look_delay_set_paused = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "delay_set_paused", "integer",
+ N_("number of seconds after typing last char: if reached, the "
+ "typing status becomes \"paused\" and no more typing signals "
+ "are sent"),
+ NULL, 1, INT_MAX, "10", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ typing_config_look_enabled_nicks = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "enabled_nicks", "boolean",
+ N_("typing enabled for other nicks (display typing info for nicks "
+ "typing in the current buffer)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &typing_config_change_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ typing_config_look_enabled_self = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "enabled_self", "boolean",
+ N_("typing enabled for self messages (send typing info to other "
+ "users)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL,
+ &typing_config_change_enabled, NULL, NULL,
+ NULL, NULL, NULL);
+ typing_config_look_input_min_chars = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "input_min_chars", "integer",
+ N_("min number of chars in message to trigger send of typing "
+ "signals"),
+ NULL, 1, INT_MAX, "4", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ typing_config_look_item_max_length = weechat_config_new_option (
+ typing_config_file, typing_config_section_look,
+ "item_max_length", "integer",
+ N_("max number of chars displayed in the bar item \"typing\" "
+ "(0 = do not truncate content)"),
+ NULL, 0, INT_MAX, "0", NULL, 0,
+ NULL, NULL, NULL,
+ &typing_config_change_item_max_length, NULL, NULL,
+ NULL, NULL, NULL);
+ }
return 1;
}
diff --git a/src/plugins/xfer/xfer-config.c b/src/plugins/xfer/xfer-config.c
index ae92ffa38..5d8d27eda 100644
--- a/src/plugins/xfer/xfer-config.c
+++ b/src/plugins/xfer/xfer-config.c
@@ -30,43 +30,52 @@
struct t_config_file *xfer_config_file = NULL;
+/* sections */
+
+struct t_config_section *xfer_config_section_look = NULL;
+struct t_config_section *xfer_config_section_color = NULL;
+struct t_config_section *xfer_config_section_network = NULL;
+struct t_config_section *xfer_config_section_file = NULL;
+
/* xfer config, look section */
-struct t_config_option *xfer_config_look_auto_open_buffer;
-struct t_config_option *xfer_config_look_progress_bar_size;
-struct t_config_option *xfer_config_look_pv_tags;
+struct t_config_option *xfer_config_look_auto_open_buffer = NULL;
+struct t_config_option *xfer_config_look_progress_bar_size = NULL;
+struct t_config_option *xfer_config_look_pv_tags = NULL;
/* xfer config, color section */
-struct t_config_option *xfer_config_color_status[XFER_NUM_STATUS];
-struct t_config_option *xfer_config_color_text;
-struct t_config_option *xfer_config_color_text_bg;
-struct t_config_option *xfer_config_color_text_selected;
+struct t_config_option *xfer_config_color_status[XFER_NUM_STATUS] = {
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+};
+struct t_config_option *xfer_config_color_text = NULL;
+struct t_config_option *xfer_config_color_text_bg = NULL;
+struct t_config_option *xfer_config_color_text_selected = NULL;
/* xfer config, network section */
-struct t_config_option *xfer_config_network_blocksize;
-struct t_config_option *xfer_config_network_fast_send;
-struct t_config_option *xfer_config_network_own_ip;
-struct t_config_option *xfer_config_network_port_range;
-struct t_config_option *xfer_config_network_send_ack;
-struct t_config_option *xfer_config_network_speed_limit_recv;
-struct t_config_option *xfer_config_network_speed_limit_send;
-struct t_config_option *xfer_config_network_timeout;
+struct t_config_option *xfer_config_network_blocksize = NULL;
+struct t_config_option *xfer_config_network_fast_send = NULL;
+struct t_config_option *xfer_config_network_own_ip = NULL;
+struct t_config_option *xfer_config_network_port_range = NULL;
+struct t_config_option *xfer_config_network_send_ack = NULL;
+struct t_config_option *xfer_config_network_speed_limit_recv = NULL;
+struct t_config_option *xfer_config_network_speed_limit_send = NULL;
+struct t_config_option *xfer_config_network_timeout = NULL;
/* xfer config, file section */
-struct t_config_option *xfer_config_file_auto_accept_chats;
-struct t_config_option *xfer_config_file_auto_accept_files;
-struct t_config_option *xfer_config_file_auto_accept_nicks;
-struct t_config_option *xfer_config_file_auto_check_crc32;
-struct t_config_option *xfer_config_file_auto_rename;
-struct t_config_option *xfer_config_file_auto_resume;
-struct t_config_option *xfer_config_file_convert_spaces;
-struct t_config_option *xfer_config_file_download_path;
-struct t_config_option *xfer_config_file_download_temporary_suffix;
-struct t_config_option *xfer_config_file_upload_path;
-struct t_config_option *xfer_config_file_use_nick_in_filename;
+struct t_config_option *xfer_config_file_auto_accept_chats = NULL;
+struct t_config_option *xfer_config_file_auto_accept_files = NULL;
+struct t_config_option *xfer_config_file_auto_accept_nicks = NULL;
+struct t_config_option *xfer_config_file_auto_check_crc32 = NULL;
+struct t_config_option *xfer_config_file_auto_rename = NULL;
+struct t_config_option *xfer_config_file_auto_resume = NULL;
+struct t_config_option *xfer_config_file_convert_spaces = NULL;
+struct t_config_option *xfer_config_file_download_path = NULL;
+struct t_config_option *xfer_config_file_download_temporary_suffix = NULL;
+struct t_config_option *xfer_config_file_upload_path = NULL;
+struct t_config_option *xfer_config_file_use_nick_in_filename = NULL;
/*
@@ -112,303 +121,295 @@ xfer_config_reload (const void *pointer, void *data,
int
xfer_config_init ()
{
- struct t_config_section *ptr_section;
-
xfer_config_file = weechat_config_new (XFER_CONFIG_PRIO_NAME,
&xfer_config_reload, NULL, NULL);
if (!xfer_config_file)
return 0;
- ptr_section = weechat_config_new_section (xfer_config_file, "look",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (xfer_config_file);
- xfer_config_file = NULL;
- return 0;
- }
-
- xfer_config_look_auto_open_buffer = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_open_buffer", "boolean",
- N_("auto open xfer buffer when a new xfer is added "
- "to list"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_look_progress_bar_size = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "progress_bar_size", "integer",
- N_("size of progress bar, in chars (if 0, progress bar is disabled)"),
- NULL, 0, XFER_CONFIG_PROGRESS_BAR_MAX_SIZE, "20", NULL, 0,
+ xfer_config_section_look = weechat_config_new_section (
+ xfer_config_file, "look",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
- xfer_config_look_pv_tags = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "pv_tags", "string",
- N_("comma separated list of tags used in private messages, for example: "
- "\"notify_message\", \"notify_private\" or \"notify_highlight\""),
- NULL, 0, 0, "notify_private", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- ptr_section = weechat_config_new_section (xfer_config_file, "color",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (xfer_config_section_look)
{
- weechat_config_free (xfer_config_file);
- xfer_config_file = NULL;
- return 0;
+ xfer_config_look_auto_open_buffer = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_look,
+ "auto_open_buffer", "boolean",
+ N_("auto open xfer buffer when a new xfer is added "
+ "to list"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_look_progress_bar_size = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_look,
+ "progress_bar_size", "integer",
+ N_("size of progress bar, in chars (if 0, progress bar is "
+ "disabled)"),
+ NULL, 0, XFER_CONFIG_PROGRESS_BAR_MAX_SIZE, "20", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_look_pv_tags = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_look,
+ "pv_tags", "string",
+ N_("comma separated list of tags used in private messages, for "
+ "example: \"notify_message\", \"notify_private\" or "
+ "\"notify_highlight\""),
+ NULL, 0, 0, "notify_private", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- xfer_config_color_status[XFER_STATUS_ABORTED] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_aborted", "color",
- N_("text color for \"aborted\" status"),
- NULL, 0, 0, "lightred", NULL, 0,
- NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_status[XFER_STATUS_ACTIVE] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_active", "color",
- N_("text color for \"active\" status"),
- NULL, 0, 0, "lightblue", NULL, 0,
+ xfer_config_section_color = weechat_config_new_section (
+ xfer_config_file, "color",
+ 0, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_status[XFER_STATUS_CONNECTING] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_connecting", "color",
- N_("text color for \"connecting\" status"),
- NULL, 0, 0, "yellow", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_status[XFER_STATUS_DONE] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_done", "color",
- N_("text color for \"done\" status"),
- NULL, 0, 0, "lightgreen", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_status[XFER_STATUS_FAILED] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_failed", "color",
- N_("text color for \"failed\" status"),
- NULL, 0, 0, "lightred", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
- xfer_config_color_status[XFER_STATUS_WAITING] = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "status_waiting", "color",
- N_("text color for \"waiting\" status"),
- NULL, 0, 0, "lightcyan", NULL, 0,
+ if (xfer_config_section_color)
+ {
+ xfer_config_color_status[XFER_STATUS_ABORTED] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_aborted", "color",
+ N_("text color for \"aborted\" status"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_status[XFER_STATUS_ACTIVE] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_active", "color",
+ N_("text color for \"active\" status"),
+ NULL, 0, 0, "lightblue", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_status[XFER_STATUS_CONNECTING] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_connecting", "color",
+ N_("text color for \"connecting\" status"),
+ NULL, 0, 0, "yellow", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_status[XFER_STATUS_DONE] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_done", "color",
+ N_("text color for \"done\" status"),
+ NULL, 0, 0, "lightgreen", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_status[XFER_STATUS_FAILED] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_failed", "color",
+ N_("text color for \"failed\" status"),
+ NULL, 0, 0, "lightred", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_status[XFER_STATUS_WAITING] = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "status_waiting", "color",
+ N_("text color for \"waiting\" status"),
+ NULL, 0, 0, "lightcyan", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_text = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "text", "color",
+ N_("text color in xfer buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_text_bg = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "text_bg", "color",
+ N_("background color in xfer buffer"),
+ NULL, 0, 0, "default", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ xfer_config_color_text_selected = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_color,
+ "text_selected", "color",
+ N_("text color of selected line in xfer buffer"),
+ NULL, 0, 0, "white", NULL, 0,
+ NULL, NULL, NULL,
+ &xfer_config_refresh_cb, NULL, NULL,
+ NULL, NULL, NULL);
+ }
+
+ xfer_config_section_network = weechat_config_new_section (
+ xfer_config_file, "network",
+ 0, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_text = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "text", "color",
- N_("text color in xfer buffer"),
- NULL, 0, 0, "default", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_text_bg = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "text_bg", "color",
- N_("background color in xfer buffer"),
- NULL, 0, 0, "default", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
- NULL, NULL, NULL);
- xfer_config_color_text_selected = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "text_selected", "color",
- N_("text color of selected line in xfer buffer"),
- NULL, 0, 0, "white", NULL, 0,
NULL, NULL, NULL,
- &xfer_config_refresh_cb, NULL, NULL,
NULL, NULL, NULL);
-
- ptr_section = weechat_config_new_section (xfer_config_file, "network",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ if (xfer_config_section_network)
{
- weechat_config_free (xfer_config_file);
- xfer_config_file = NULL;
- return 0;
+ xfer_config_network_blocksize = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "blocksize", "integer",
+ N_("block size for sending packets, in bytes"),
+ NULL, XFER_BLOCKSIZE_MIN, XFER_BLOCKSIZE_MAX, "65536", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_fast_send = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "fast_send", "boolean",
+ N_("does not wait for ACK when sending file"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_own_ip = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "own_ip", "string",
+ N_("IP or DNS address used for sending files/chats "
+ "(if empty, local interface IP is used)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_port_range = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "port_range", "string",
+ N_("restricts outgoing files/chats to use only ports in the given "
+ "range (useful for NAT) (syntax: a single port, ie. 5000 or a "
+ "port range, ie. 5000-5015, empty value means any port, it's "
+ "recommended to use ports greater than 1024, because only root "
+ "can use ports below 1024)"),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_send_ack = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "send_ack", "boolean",
+ N_("send acks when receiving files; if disabled, the transfer may "
+ "freeze if the sender is waiting for acks (for example a "
+ "WeeChat sending a file with option xfer.network.fast_send set "
+ "to off); on the other hand, disabling send of acks may prevent "
+ "a freeze if the acks are not sent immediately to the sender"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_speed_limit_recv = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "speed_limit_recv", "integer",
+ N_("speed limit for receiving files, in kilo-bytes by second (0 "
+ "means no limit)"),
+ NULL, 0, INT_MAX, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_speed_limit_send = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "speed_limit_send", "integer",
+ N_("speed limit for sending files, in kilo-bytes by second (0 means "
+ "no limit)"),
+ NULL, 0, INT_MAX, "0", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_network_timeout = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_network,
+ "timeout", "integer",
+ N_("timeout for xfer request (in seconds)"),
+ NULL, 5, INT_MAX, "300", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- xfer_config_network_blocksize = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "blocksize", "integer",
- N_("block size for sending packets, in bytes"),
- NULL, XFER_BLOCKSIZE_MIN, XFER_BLOCKSIZE_MAX, "65536", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_fast_send = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "fast_send", "boolean",
- N_("does not wait for ACK when sending file"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_own_ip = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "own_ip", "string",
- N_("IP or DNS address used for sending files/chats "
- "(if empty, local interface IP is used)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_port_range = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "port_range", "string",
- N_("restricts outgoing files/chats to use only ports in the given "
- "range (useful for NAT) (syntax: a single port, ie. 5000 or a port "
- "range, ie. 5000-5015, empty value means any port, it's recommended "
- "to use ports greater than 1024, because only root can use ports "
- "below 1024)"),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_send_ack = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "send_ack", "boolean",
- N_("send acks when receiving files; if disabled, the transfer may "
- "freeze if the sender is waiting for acks (for example a WeeChat "
- "sending a file with option xfer.network.fast_send set to off); "
- "on the other hand, disabling send of acks may prevent a freeze if "
- "the acks are not sent immediately to the sender"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_speed_limit_recv = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "speed_limit_recv", "integer",
- N_("speed limit for receiving files, in kilo-bytes by second (0 means "
- "no limit)"),
- NULL, 0, INT_MAX, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_speed_limit_send = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "speed_limit_send", "integer",
- N_("speed limit for sending files, in kilo-bytes by second (0 means "
- "no limit)"),
- NULL, 0, INT_MAX, "0", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_network_timeout = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "timeout", "integer",
- N_("timeout for xfer request (in seconds)"),
- NULL, 5, INT_MAX, "300", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- ptr_section = weechat_config_new_section (xfer_config_file, "file",
- 0, 0,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL,
- NULL, NULL, NULL);
- if (!ptr_section)
+ xfer_config_section_file = weechat_config_new_section (
+ xfer_config_file, "file",
+ 0, 0,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL,
+ NULL, NULL, NULL);
+ if (xfer_config_section_file)
{
- weechat_config_free (xfer_config_file);
- xfer_config_file = NULL;
- return 0;
+ xfer_config_file_auto_accept_chats = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_accept_chats", "boolean",
+ N_("automatically accept chat requests (use carefully!)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_auto_accept_files = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_accept_files", "boolean",
+ N_("automatically accept incoming files (use carefully!)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_auto_accept_nicks = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_accept_nicks", "string",
+ N_("comma-separated list of nicks for which the incoming files and "
+ "chats are automatically accepted; format is \"server.nick\" "
+ "(for a specific server) or \"nick\" (for all servers); "
+ "example: \"libera.FlashCode,andrew\""),
+ NULL, 0, 0, "", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_auto_check_crc32 = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_check_crc32", "boolean",
+ N_("automatically check CRC32 file checksum if it is found in the "
+ "filename (8 hexadecimal chars)"),
+ NULL, 0, 0, "off", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_auto_rename = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_rename", "boolean",
+ N_("rename incoming files if already exists (add \".1\", \".2\", "
+ "...)"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_auto_resume = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "auto_resume", "boolean",
+ N_("automatically resume file transfer if connection with remote "
+ "host is lost"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_convert_spaces = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "convert_spaces", "boolean",
+ N_("convert spaces to underscores when sending and receiving "
+ "files"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_download_path = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "download_path", "string",
+ N_("path for writing incoming files "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "${weechat_data_dir}/xfer", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_download_temporary_suffix = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "download_temporary_suffix", "string",
+ N_("temporary filename suffix used during the transfer for a file "
+ "received, it is removed after successful transfer; "
+ "if empty string, no filename suffix is used during the "
+ "transfer"),
+ NULL, 0, 0, ".part", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_upload_path = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "upload_path", "string",
+ N_("path for reading files when sending "
+ "(path is evaluated, see function string_eval_path_home in "
+ "plugin API reference)"),
+ NULL, 0, 0, "~", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+ xfer_config_file_use_nick_in_filename = weechat_config_new_option (
+ xfer_config_file, xfer_config_section_file,
+ "use_nick_in_filename", "boolean",
+ N_("use remote nick as prefix in local filename when receiving a "
+ "file"),
+ NULL, 0, 0, "on", NULL, 0,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}
- xfer_config_file_auto_accept_chats = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_accept_chats", "boolean",
- N_("automatically accept chat requests (use carefully!)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_auto_accept_files = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_accept_files", "boolean",
- N_("automatically accept incoming files (use carefully!)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_auto_accept_nicks = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_accept_nicks", "string",
- N_("comma-separated list of nicks for which the incoming files and "
- "chats are automatically accepted; format is \"server.nick\" (for a "
- "specific server) or \"nick\" (for all servers); example: "
- "\"libera.FlashCode,andrew\""),
- NULL, 0, 0, "", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_auto_check_crc32 = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_check_crc32", "boolean",
- N_("automatically check CRC32 file checksum if it is found in the "
- "filename (8 hexadecimal chars)"),
- NULL, 0, 0, "off", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_auto_rename = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_rename", "boolean",
- N_("rename incoming files if already exists (add \".1\", \".2\", ...)"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_auto_resume = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "auto_resume", "boolean",
- N_("automatically resume file transfer if connection with remote host "
- "is lost"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_convert_spaces = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "convert_spaces", "boolean",
- N_("convert spaces to underscores when sending and receiving files"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_download_path = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "download_path", "string",
- N_("path for writing incoming files "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "${weechat_data_dir}/xfer", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_download_temporary_suffix = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "download_temporary_suffix", "string",
- N_("temporary filename suffix used during the transfer for a file "
- "received, it is removed after successful transfer; "
- "if empty string, no filename suffix is used during the transfer"),
- NULL, 0, 0, ".part", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_upload_path = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "upload_path", "string",
- N_("path for reading files when sending "
- "(path is evaluated, see function string_eval_path_home in "
- "plugin API reference)"),
- NULL, 0, 0, "~", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- xfer_config_file_use_nick_in_filename = weechat_config_new_option (
- xfer_config_file, ptr_section,
- "use_nick_in_filename", "boolean",
- N_("use remote nick as prefix in local filename when receiving a file"),
- NULL, 0, 0, "on", NULL, 0,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
return 1;
}