X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/da5d424313f0a193b9bf8aec463c4b71b84e91d4..3b7fa78b1de8f9ee8718cba3da3b2db522b70620:/src/hash.c diff --git a/src/hash.c b/src/hash.c index c45e5a3..4fa4f51 100644 --- a/src/hash.c +++ b/src/hash.c @@ -50,6 +50,18 @@ void init_structs(void) reg_exit_func(hash_cleanup); } +int userList_contains(struct userList *list, struct userNode *user) +{ + unsigned int ii; + + for (ii = 0; ii < list->used; ++ii) { + if (user == list->list[ii]) { + return 1; + } + } + return 0; +} + server_link_func_t *slf_list; unsigned int slf_size = 0, slf_used = 0; @@ -189,7 +201,7 @@ NickChange(struct userNode* user, const char *new_nick, int no_announce) /* Make callbacks for nick changes. Do this with new nick in * place because that is slightly more useful. */ - for (nn=0; nndead; nn++) ncf2_list[nn](user, old_nick); user->timestamp = now; if (IsLocal(user) && !no_announce) @@ -224,7 +236,7 @@ SVSNickChange(struct userNode* user, const char *new_nick) /* Make callbacks for nick changes. Do this with new nick in * place because that is slightly more useful. */ - for (nn=0; nndead; nn++) ncf2_list[nn](user, old_nick); user->timestamp = now; @@ -549,6 +561,7 @@ DelChannel(struct chanNode *channel) { unsigned int n; + verify(channel); dict_remove(channels, channel->name); if (channel->members.used || channel->locks) { @@ -557,7 +570,7 @@ DelChannel(struct chanNode *channel) /* go through all channel members and delete them from the channel */ for (n=channel->members.used; n>0; ) - DelChannelUser(channel->members.list[--n]->user, channel, false, 1); + DelChannelUser(channel->members.list[--n]->user, channel, NULL, 1); /* delete all channel bans */ for (n=channel->banlist.used; n>0; ) @@ -606,19 +619,22 @@ AddChannelUser(struct userNode *user, struct chanNode* channel) if (channel->members.used == 1 && !(channel->modes & MODE_REGISTERED) - && !(channel->modes & MODE_APASS)) + && !(channel->modes & MODE_APASS)) { mNode->modes |= MODE_CHANOP; + log_module(MAIN_LOG, LOG_DEBUG, "setting op"); + } - for (n=0; ndead; n++) { /* Callbacks return true if they kick or kill the user, * and we can continue without removing mNode. */ if (jf_list[n](mNode)) return NULL; } - if (IsLocal(user)) - irc_join(user, channel); - return mNode; } @@ -673,7 +689,7 @@ DelChannelUser(struct userNode* user, struct chanNode* channel, const char *reas struct modeNode* mNode; unsigned int n; - if (reason) + if (IsLocal(user) && reason) irc_part(user, channel, reason); mNode = GetUserMode(channel, user); @@ -827,6 +843,10 @@ SetChannelTopic(struct chanNode *channel, struct userNode *service, struct userN irc_topic(service, user, channel, topic); } else { for (n=0; n