summaryrefslogtreecommitdiff
path: root/src/fe-common/irc
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-09-22 10:26:52 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-09-22 10:26:52 +0000
commitf76248133a495007c0ecf37ac37111dff9264067 (patch)
tree6324e7e29f04ff6da22f24664ddf33ebe8d3596f /src/fe-common/irc
parente316475afd4e77e6507c662ee272e5ed07893f85 (diff)
downloadirssi-f76248133a495007c0ecf37ac37111dff9264067.zip
/SET completion_nicks_lowercase
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@664 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-common/irc')
-rw-r--r--src/fe-common/irc/irc-completion.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/fe-common/irc/irc-completion.c b/src/fe-common/irc/irc-completion.c
index 06ec7598..532002b0 100644
--- a/src/fe-common/irc/irc-completion.c
+++ b/src/fe-common/irc/irc-completion.c
@@ -384,9 +384,11 @@ static GList *completion_msg(IRC_SERVER_REC *win_server,
}
static void complete_from_nicklist(GList **outlist, GSList *list,
- const char *nick, const char *prefix)
+ const char *nick, const char *prefix,
+ int lowercase)
{
GSList *tmp;
+ char *str;
int len;
len = strlen(nick);
@@ -396,9 +398,11 @@ static void complete_from_nicklist(GList **outlist, GSList *list,
if (g_strncasecmp(rec->nick, nick, len) == 0 &&
glist_find_icase_string(*outlist, rec->nick) == NULL) {
if (prefix == NULL || *prefix == '\0')
- *outlist = g_list_append(*outlist, g_strdup(rec->nick));
+ str = g_strdup(rec->nick);
else
- *outlist = g_list_append(*outlist, g_strconcat(rec->nick, prefix, NULL));
+ str = g_strconcat(rec->nick, prefix, NULL);
+ if (lowercase) g_strdown(str);
+ *outlist = g_list_append(*outlist, str);
}
}
}
@@ -408,17 +412,19 @@ static GList *completion_channel_nicks(IRC_CHANNEL_REC *channel, const char *nic
MODULE_CHANNEL_REC *mchannel;
GSList *nicks, *tmp;
GList *list;
- int len;
+ int lowercase, len;
g_return_val_if_fail(channel != NULL, NULL);
g_return_val_if_fail(nick != NULL, NULL);
if (*nick == '\0') return NULL;
+
+ lowercase = settings_get_bool("completion_nicks_lowercase");
/* put first the nicks who have recently said something [to you] */
list = NULL;
mchannel = MODULE_DATA(channel);
- complete_from_nicklist(&list, mchannel->lastownmsgs, nick, prefix);
- complete_from_nicklist(&list, mchannel->lastmsgs, nick, prefix);
+ complete_from_nicklist(&list, mchannel->lastownmsgs, nick, prefix, lowercase);
+ complete_from_nicklist(&list, mchannel->lastmsgs, nick, prefix, lowercase);
/* and add the rest of the nicks too */
len = strlen(nick);
@@ -429,10 +435,13 @@ static GList *completion_channel_nicks(IRC_CHANNEL_REC *channel, const char *nic
if (g_strncasecmp(rec->nick, nick, len) == 0 &&
glist_find_icase_string(list, rec->nick) == NULL &&
g_strcasecmp(rec->nick, channel->server->nick) != 0) {
+ char *str;
if (prefix == NULL || *prefix == '\0')
- list = g_list_append(list, g_strdup(rec->nick));
+ str = g_strdup(rec->nick);
else
- list = g_list_append(list, g_strconcat(rec->nick, prefix, NULL));
+ str = g_strconcat(rec->nick, prefix, NULL);
+ if (lowercase) g_strdown(str);
+ list = g_list_append(list, str);
}
}
g_slist_free(nicks);
@@ -708,6 +717,7 @@ void irc_completion_init(void)
settings_add_int("completion", "completion_keep_ownpublics", 360);
settings_add_int("completion", "completion_keep_privates", 10);
settings_add_bool("completion", "expand_escapes", FALSE);
+ settings_add_bool("completion", "completion_nicks_lowercase", FALSE);
complete_tag = g_timeout_add(1000, (GSourceFunc) nick_completion_timeout, NULL);