summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/plugins/irc/irc-channel.c30
-rw-r--r--src/plugins/irc/irc-completion.c61
-rw-r--r--src/plugins/irc/irc-config.c10
-rw-r--r--src/plugins/irc/irc-config.h4
4 files changed, 70 insertions, 35 deletions
diff --git a/src/plugins/irc/irc-channel.c b/src/plugins/irc/irc-channel.c
index 537d18bf7..b5c2d8af6 100644
--- a/src/plugins/irc/irc-channel.c
+++ b/src/plugins/irc/irc-channel.c
@@ -307,21 +307,17 @@ irc_channel_set_away (struct t_irc_channel *channel, const char *nick_name,
}
/*
- * irc_channel_nick_speaking_add: add a nick speaking on a channel
+ * irc_channel_nick_speaking_add_to_list: add a nick speaking on a channel
*/
void
-irc_channel_nick_speaking_add (struct t_irc_channel *channel,
- const char *nick_name, int highlight)
+irc_channel_nick_speaking_add_to_list (struct t_irc_channel *channel,
+ const char *nick_name,
+ int highlight)
{
int size, to_remove, i;
struct t_weelist_item *ptr_item;
- if (highlight < 0)
- highlight = 0;
- if (highlight > 1)
- highlight = 1;
-
/* create list if it does not exist */
if (!channel->nicks_speaking[highlight])
channel->nicks_speaking[highlight] = weechat_list_new ();
@@ -350,6 +346,24 @@ irc_channel_nick_speaking_add (struct t_irc_channel *channel,
}
/*
+ * irc_channel_nick_speaking_add: add a nick speaking on a channel
+ */
+
+void
+irc_channel_nick_speaking_add (struct t_irc_channel *channel,
+ const char *nick_name, int highlight)
+{
+ if (highlight < 0)
+ highlight = 0;
+ if (highlight > 1)
+ highlight = 1;
+ if (highlight)
+ irc_channel_nick_speaking_add_to_list (channel, nick_name, 1);
+
+ irc_channel_nick_speaking_add_to_list (channel, nick_name, 0);
+}
+
+/*
* irc_channel_nick_speaking_rename: rename a nick speaking on a channel
*/
diff --git a/src/plugins/irc/irc-completion.c b/src/plugins/irc/irc-completion.c
index 3ca5d69a2..0de87a2ca 100644
--- a/src/plugins/irc/irc-completion.c
+++ b/src/plugins/irc/irc-completion.c
@@ -177,6 +177,36 @@ irc_completion_channel_cb (void *data, const char *completion_item,
}
/*
+ * irc_completion_channel_nicks_add_speakers: add recent speakers to completion
+ * list
+ */
+
+void
+irc_completion_channel_nicks_add_speakers (struct t_gui_completion *completion,
+ struct t_irc_channel *channel,
+ int highlight)
+{
+ int list_size, i;
+ const char *nick;
+
+ if (channel->nicks_speaking[highlight])
+ {
+ list_size = weechat_list_size (channel->nicks_speaking[highlight]);
+ for (i = 0; i < list_size; i++)
+ {
+ nick = weechat_list_string (weechat_list_get (channel->nicks_speaking[highlight], i));
+ if (nick && irc_nick_search (channel, nick))
+ {
+ weechat_hook_completion_list_add (completion,
+ nick,
+ 1,
+ WEECHAT_LIST_POS_BEGINNING);
+ }
+ }
+ }
+}
+
+/*
* irc_completion_channel_nicks_cb: callback for completion with nicks
* of current channel
*/
@@ -187,8 +217,6 @@ irc_completion_channel_nicks_cb (void *data, const char *completion_item,
struct t_gui_completion *completion)
{
struct t_irc_nick *ptr_nick;
- const char *nick;
- int list_size, i, j;
IRC_GET_SERVER_CHANNEL(buffer);
@@ -209,28 +237,15 @@ irc_completion_channel_nicks_cb (void *data, const char *completion_item,
1,
WEECHAT_LIST_POS_SORT);
}
- /* add nicks speaking recently on this channel */
- if (weechat_config_boolean (irc_config_look_nick_completion_smart))
+ /* add recent speakers on channel */
+ if (weechat_config_integer (irc_config_look_nick_completion_smart) == IRC_CONFIG_NICK_COMPLETION_SMART_SPEAKERS)
{
- /* 0 => nick speaking ; 1 => nick speaking to me (with highlight) */
- for (i = 0; i < 2; i++)
- {
- if (ptr_channel->nicks_speaking[i])
- {
- list_size = weechat_list_size (ptr_channel->nicks_speaking[i]);
- for (j = 0; j < list_size; j++)
- {
- nick = weechat_list_string (weechat_list_get (ptr_channel->nicks_speaking[i], j));
- if (nick && irc_nick_search (ptr_channel, nick))
- {
- weechat_hook_completion_list_add (completion,
- nick,
- 1,
- WEECHAT_LIST_POS_BEGINNING);
- }
- }
- }
- }
+ irc_completion_channel_nicks_add_speakers (completion, ptr_channel, 0);
+ }
+ /* add nicks whose make highlights on me recently on this channel */
+ if (weechat_config_integer (irc_config_look_nick_completion_smart) == IRC_CONFIG_NICK_COMPLETION_SMART_SPEAKERS_HIGHLIGHTS)
+ {
+ irc_completion_channel_nicks_add_speakers (completion, ptr_channel, 1);
}
/* add self nick at the end */
weechat_hook_completion_list_add (completion,
diff --git a/src/plugins/irc/irc-config.c b/src/plugins/irc/irc-config.c
index f7bb28ffa..20cf063bc 100644
--- a/src/plugins/irc/irc-config.c
+++ b/src/plugins/irc/irc-config.c
@@ -1060,14 +1060,16 @@ irc_config_init ()
NULL, 0, 0, "", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL);
irc_config_look_nick_completion_smart = weechat_config_new_option (
irc_config_file, ptr_section,
- "nick_completion_smart", "boolean",
- N_("smart completion for nicks (completes with last speakers first)"),
- NULL, 0, 0, "on", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL);
+ "nick_completion_smart", "integer",
+ N_("smart completion for nicks (completes first with last speakers)"),
+ "off|speakers|speakers_highlights", 0, 0, "speakers", NULL, 0, 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|local|channel", 0, 0, "local", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL);
+ "off|local|channel", 0, 0, "local", NULL, 0, NULL, NULL, NULL, NULL,
+ NULL, NULL);
irc_config_look_display_channel_modes = weechat_config_new_option (
irc_config_file, ptr_section,
"display_channel_modes", "boolean",
diff --git a/src/plugins/irc/irc-config.h b/src/plugins/irc/irc-config.h
index 0a09e6b8a..44a46d288 100644
--- a/src/plugins/irc/irc-config.h
+++ b/src/plugins/irc/irc-config.h
@@ -22,6 +22,10 @@
#define IRC_CONFIG_NAME "irc"
+#define IRC_CONFIG_NICK_COMPLETION_SMART_OFF 0
+#define IRC_CONFIG_NICK_COMPLETION_SMART_SPEAKERS 1
+#define IRC_CONFIG_NICK_COMPLETION_SMART_SPEAKERS_HIGHLIGHTS 2
+
#define IRC_CONFIG_DISPLAY_AWAY_OFF 0
#define IRC_CONFIG_DISPLAY_AWAY_LOCAL 1
#define IRC_CONFIG_DISPLAY_AWAY_CHANNEL 2