diff options
author | C. McEnroe | 2020-06-24 13:36:24 -0400 |
---|---|---|
committer | C. McEnroe | 2020-06-24 13:36:24 -0400 |
commit | 94fb9798c5476a9a3111f3982f357920b18c2fd0 (patch) | |
tree | 7f115ff5bd80a4190081fe02df80f209b950ad27 /command.c | |
parent | 4fb94a1a223867af1db5252ab39ccc56c585fccb (diff) |
Bump ParamCap to 254
Apparently IRCds have decided that the 15-parameter limit doesn't matter anymore. 254 is the maximum number of single-byte parameters (following a single-byte command) which fit in a 512-byte CR-LF-terminated line. When everyone decides that the 512-byte line length limit doesn't matter either, I will delete my software and people can use some JavaScript garbage instead. This makes struct Message 2080 bytes, but there's only ever one or two of them around at once. Avoid passing it by value to handle.
Diffstat (limited to 'command.c')
-rw-r--r-- | command.c | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/command.c b/command.c index 90732f3..ac83f3f 100644 --- a/command.c +++ b/command.c @@ -61,7 +61,7 @@ static void echoMessage(char *cmd, uint id, char *params) { .params[0] = idNames[id], .params[1] = params, }; - handle(msg); + handle(&msg); } static void splitMessage(char *cmd, uint id, char *params) { @@ -213,9 +213,7 @@ static void channelListMode(uint id, char pm, char l, const char *params) { for (const char *ch = params; *ch; ++ch) { if (*ch == ' ') count++; } - char modes[ParamCap - 2 + 1] = { - l, l, l, l, l, l, l, l, l, l, l, l, l, '\0' - }; + char modes[13 + 1] = { l, l, l, l, l, l, l, l, l, l, l, l, l, '\0' }; ircFormat("MODE %s %c%.*s %s\r\n", idNames[id], pm, count, modes, params); } |