summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Bratch <luke@bratch.co.uk>2019-10-02 19:37:16 +0100
committerLuke Bratch <luke@bratch.co.uk>2019-10-02 19:37:16 +0100
commit2385f7b944bb22acd85e6c089e509880a45a2cb1 (patch)
tree149c7005acbcc3aeb663661ed4b45ef7eef35ade
parentbe3913f22cc03a6d804d720fb0d3efcc337c4150 (diff)
Try to make removenickfromallchannels() much faster when another user QUITs by ignoring unused channel indexes.
-rw-r--r--TODO2
-rw-r--r--functions.c4
-rw-r--r--message.c2
3 files changed, 5 insertions, 3 deletions
diff --git a/TODO b/TODO
index a74bd7d..2407007 100644
--- a/TODO
+++ b/TODO
@@ -7,5 +7,3 @@ Add a make install/uninstall/etc., add an "INSTALL" file, include a dependency l
macOS compiler may need limits.h included in structures.h.
replaymode = "lastspoke" causes huge amounts of spam from extractnickfromprefix() and friends in full debug mode.
-
-Very slow processing of removenickfromallchannels() when another user QUITs (sometimes).
diff --git a/functions.c b/functions.c
index 730819f..c5e3cdc 100644
--- a/functions.c
+++ b/functions.c
@@ -1432,6 +1432,10 @@ int removenickfromallchannels(char *nickuserhost, struct channel *channels) {
// Go through all channels and remove nick if present
for (int i = 0; i < MAXCHANNELS; i++) {
+ // Don't bother checking this channel index if it isn't used
+ if (!channels[i].name[0]) {
+ continue;
+ }
// Go through all nicks in channel
for (int j = 0; j < MAXCHANNICKS; j++) {
// Remove the nick from the channel if present
diff --git a/message.c b/message.c
index a187655..a2c16e4 100644
--- a/message.c
+++ b/message.c
@@ -267,7 +267,7 @@ int processservermessage(SSL *server_ssl, char *str, struct client *clients, int
if (strncmp(tokens[1], "QUIT", strlen(tokens[1])) == 0) {
debugprint(DEBUG_FULL, "Server QUIT found and it is: %s with length %zd! Next token is '%s'.\n", tokens[0], strlen(tokens[0]), tokens[2]);
- // And then send to all clients
+ // Tell all clients
sendtoallclients(clients, str, sourcefd, settings);
// Write to replay log if replay logging enabled