diff options
author | Robin Burchell w00t@inspircd.org <Robin Burchell w00t@inspircd.org@5417fbe8-f217-4b02-8779-1006273d7864> | 2008-09-30 18:45:11 +0000 |
---|---|---|
committer | Robin Burchell w00t@inspircd.org <Robin Burchell w00t@inspircd.org@5417fbe8-f217-4b02-8779-1006273d7864> | 2008-09-30 18:45:11 +0000 |
commit | c4d520b465f8aa7f5924b17b697fa760b6ead409 (patch) | |
tree | 96f6c2164077f7319bc6be855ce250e23ec9f07d /src | |
parent | 76cc8d0462422eed9d7af255b152c24697821309 (diff) |
Move some stuff to BotInfo methods.
git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@1232 5417fbe8-f217-4b02-8779-1006273d7864
Diffstat (limited to 'src')
-rw-r--r-- | src/bots.cpp | 29 | ||||
-rw-r--r-- | src/botserv.c | 16 | ||||
-rw-r--r-- | src/core/bs_assign.c | 8 | ||||
-rw-r--r-- | src/core/bs_unassign.c | 2 |
4 files changed, 31 insertions, 24 deletions
diff --git a/src/bots.cpp b/src/bots.cpp index 487cc6dc7..29f51f0e0 100644 --- a/src/bots.cpp +++ b/src/bots.cpp @@ -45,3 +45,32 @@ void BotInfo::RejoinAll() if (ci->bi == this && ci->c && (ci->c->usercount >= BSMinUsers)) bot_join(ci); } + +void BotInfo::Assign(User *u, ChannelInfo *ci) +{ + if (ci->bi) + { + if (u) + ci->bi->UnAssign(u, ci); + else + ci->bi->UnAssign(NULL, ci); + } + + ci->bi = this; + this->chancount++; + if (ci->c && ci->c->usercount >= BSMinUsers) + bot_join(ci); +} + +void BotInfo::UnAssign(User *u, ChannelInfo *ci) +{ + send_event(EVENT_BOT_UNASSIGN, 2, ci->name, ci->bi->nick); + + if (u && ci->c && ci->c->usercount >= BSMinUsers) + anope_cmd_part(ci->bi->nick, ci->name, "UNASSIGN from %s", u->nick); + + ci->bi->chancount--; + ci->bi = NULL; +} + + diff --git a/src/botserv.c b/src/botserv.c index 7fd029153..745acb47c 100644 --- a/src/botserv.c +++ b/src/botserv.c @@ -617,22 +617,6 @@ BotInfo *findbot(const char *nick) /*************************************************************************/ -/* Unassign a bot from a channel. Assumes u, ci and ci->bi are not NULL */ - -void unassign(User * u, ChannelInfo * ci) -{ - send_event(EVENT_BOT_UNASSIGN, 2, ci->name, ci->bi->nick); - - if (ci->c && ci->c->usercount >= BSMinUsers) { - anope_cmd_part(ci->bi->nick, ci->name, "UNASSIGN from %s", - u->nick); - } - ci->bi->chancount--; - ci->bi = NULL; -} - -/*************************************************************************/ - /* Returns ban data associated with an user if it exists, allocates it otherwise. */ diff --git a/src/core/bs_assign.c b/src/core/bs_assign.c index e34ca7d81..22c9d9c17 100644 --- a/src/core/bs_assign.c +++ b/src/core/bs_assign.c @@ -88,13 +88,7 @@ int do_assign(User * u) || (!check_access(u, ci, CA_ASSIGN) && !is_services_admin(u))) notice_lang(s_BotServ, u, PERMISSION_DENIED); else { - if (ci->bi) - unassign(u, ci); - ci->bi = bi; - bi->chancount++; - if (ci->c && ci->c->usercount >= BSMinUsers) { - bot_join(ci); - } + notice_lang(s_BotServ, u, BOT_ASSIGN_ASSIGNED, bi->nick, ci->name); send_event(EVENT_BOT_ASSIGN, 2, ci->name, bi->nick); } diff --git a/src/core/bs_unassign.c b/src/core/bs_unassign.c index a5e0af6bb..3dcb15506 100644 --- a/src/core/bs_unassign.c +++ b/src/core/bs_unassign.c @@ -82,7 +82,7 @@ int do_unassign(User * u) else if (!ci->bi) notice_help(s_BotServ, u, BOT_NOT_ASSIGNED); else { - unassign(u, ci); + ci->bi->UnAssign(u, ci); notice_lang(s_BotServ, u, BOT_UNASSIGN_UNASSIGNED, ci->name); } return MOD_CONT; |