summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to 'modules')
-rw-r--r--modules/commands/cs_set.cpp4
-rw-r--r--modules/pseudoclients/botserv.cpp9
2 files changed, 2 insertions, 11 deletions
diff --git a/modules/commands/cs_set.cpp b/modules/commands/cs_set.cpp
index 730f31deb..97948b0a4 100644
--- a/modules/commands/cs_set.cpp
+++ b/modules/commands/cs_set.cpp
@@ -540,8 +540,6 @@ class CommandCSSetPersist : public Command
if (!ci->HasExt("PERSIST"))
{
ci->ExtendMetadata("PERSIST");
- if (ci->c)
- ci->c->Extend("PERSIST");
/* Channel doesn't exist, create it */
if (!ci->c)
@@ -583,8 +581,6 @@ class CommandCSSetPersist : public Command
if (ci->HasExt("PERSIST"))
{
ci->Shrink("PERSIST");
- if (ci->c)
- ci->c->Shrink("PERSIST");
/* Unset perm mode */
if (cm)
diff --git a/modules/pseudoclients/botserv.cpp b/modules/pseudoclients/botserv.cpp
index 2c506876a..2f157b809 100644
--- a/modules/pseudoclients/botserv.cpp
+++ b/modules/pseudoclients/botserv.cpp
@@ -184,7 +184,7 @@ class BotServCore : public Module
void OnLeaveChannel(User *u, Channel *c) anope_override
{
/* Channel is persistent, it shouldn't be deleted and the service bot should stay */
- if (c->HasExt("PERSIST") || (c->ci && c->ci->HasExt("PERSIST")))
+ if (c->ci && c->ci->HasExt("PERSIST"))
return;
/* Channel is syncing from a netburst, don't destroy it as more users are probably wanting to join immediatly
@@ -197,14 +197,9 @@ class BotServCore : public Module
if (c->HasExt("INHABIT"))
return;
+ /* This is called prior to removing the user from the channnel, so c->users.size() - 1 should be safe */
if (c->ci && c->ci->bi && u != *c->ci->bi && c->users.size() - 1 <= Config->BSMinUsers && c->FindUser(c->ci->bi))
- {
- bool persist = c->Shrink("PERSIST");
- c->Extend("PERSIST");
c->ci->bi->Part(c->ci->c);
- if (!persist)
- c->Shrink("PERSIST");
- }
}
EventReturn OnPreHelp(CommandSource &source, const std::vector<Anope::string> &params) anope_override