diff options
author | Timo Sirainen <cras@irssi.org> | 2000-08-26 00:35:32 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2000-08-26 00:35:32 +0000 |
commit | 3d124da13b8da5c0b535abfe6265fc471d9d2ebd (patch) | |
tree | 33b220e072c06e97523266fba900d7f5fbc0e917 /src/irc | |
parent | 2e886d62f5342e41ddb9dfc8660036667214b1c5 (diff) | |
download | irssi-3d124da13b8da5c0b535abfe6265fc471d9d2ebd.zip |
Some fixes to handling +l and +k mode.
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@631 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/irc')
-rw-r--r-- | src/irc/core/modes.c | 34 |
1 files changed, 24 insertions, 10 deletions
diff --git a/src/irc/core/modes.c b/src/irc/core/modes.c index c3331dfe..ad4154b4 100644 --- a/src/irc/core/modes.c +++ b/src/irc/core/modes.c @@ -58,7 +58,7 @@ static int mode_is_set(const char *str, char mode) } /* add argument to specified position */ -static void mode_add_arg(GString *str, int pos, const char *arg) +static void mode_add_arg(GString *str, int pos, int updating, const char *arg) { char *p; @@ -71,12 +71,19 @@ static void mode_add_arg(GString *str, int pos, const char *arg) pos--; } + pos = (int) (p-str->str); + if (updating && *p != '\0') { + /* remove the old argument */ + p++; + while (*p != '\0' && *p != ' ') p++; + g_string_erase(str, pos, (int) (p-str->str)-pos); + } + /* .. GLib shouldn't fail when inserting at the end of the string */ - if (*p == '\0') { + if (pos == str->len) { g_string_append_c(str, ' '); g_string_append(str, arg); } else { - pos = (int) (p-str->str); g_string_insert_c(str, pos, ' '); g_string_insert(str, pos+1, arg); } @@ -86,26 +93,33 @@ static void mode_add_arg(GString *str, int pos, const char *arg) static void mode_add_sorted(GString *str, char mode, const char *arg) { char *p; - int argpos = 0; + int updating, argpos = 0; /* check that mode isn't already set */ - if (mode_is_set(str->str, mode)) + if (!HAS_MODE_ARG_SET(mode) && mode_is_set(str->str, mode)) return; + updating = FALSE; for (p = str->str; *p != '\0' && *p != ' '; p++) { if (mode < *p) break; + if (mode == *p) { + updating = TRUE; + break; + } if (HAS_MODE_ARG_SET(*p)) argpos++; } /* .. GLib shouldn't fail when inserting at the end of the string */ - if (*p == '\0') - g_string_append_c(str, mode); - else - g_string_insert_c(str, (int) (p-str->str), mode); + if (!updating) { + if (*p == '\0') + g_string_append_c(str, mode); + else + g_string_insert_c(str, (int) (p-str->str), mode); + } if (arg != NULL) - mode_add_arg(str, argpos+1, arg); + mode_add_arg(str, argpos, updating, arg); } /* remove the n'th argument */ |