summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/bots.cpp29
-rw-r--r--src/botserv.c16
-rw-r--r--src/core/bs_assign.c8
-rw-r--r--src/core/bs_unassign.c2
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;