diff options
author | Adam <Adam@anope.org> | 2010-07-31 21:37:45 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-07-31 21:37:45 -0400 |
commit | c770c47e18121e93bcdd06b1ab5f161440ffcfe2 (patch) | |
tree | 8e80d54507ab705e2dc51278c533c6000c8af1da /modules/core/cs_set_topiclock.cpp | |
parent | 9d0d44d738705a457ce08599ba50c97033a43c71 (diff) |
Don't dynamically allocate commands in modules anymore, instead made them members of modules. This means the commands are automatically destructed when the module is unloaded. Cleans up some old ugly code.
Diffstat (limited to 'modules/core/cs_set_topiclock.cpp')
-rw-r--r-- | modules/core/cs_set_topiclock.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/modules/core/cs_set_topiclock.cpp b/modules/core/cs_set_topiclock.cpp index b60a687b4..44ae5390c 100644 --- a/modules/core/cs_set_topiclock.cpp +++ b/modules/core/cs_set_topiclock.cpp @@ -16,7 +16,7 @@ class CommandCSSetTopicLock : public Command { public: - CommandCSSetTopicLock(const Anope::string &cname, const Anope::string &cpermission = "") : Command(cname, 2, 2, cpermission) + CommandCSSetTopicLock(const Anope::string &cpermission = "") : Command("TOPICLOCK", 2, 2, cpermission) { } @@ -62,7 +62,7 @@ class CommandCSSetTopicLock : public Command class CommandCSSASetTopicLock : public CommandCSSetTopicLock { public: - CommandCSSASetTopicLock(const Anope::string &cname) : CommandCSSetTopicLock(cname, "chanserv/saset/topiclock") + CommandCSSASetTopicLock() : CommandCSSetTopicLock("chanserv/saset/topiclock") { } @@ -80,6 +80,9 @@ class CommandCSSASetTopicLock : public CommandCSSetTopicLock class CSSetTopicLock : public Module { + CommandCSSetTopicLock commandcssettopiclock; + CommandCSSASetTopicLock commandcssasettopiclock; + public: CSSetTopicLock(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator) { @@ -88,22 +91,22 @@ class CSSetTopicLock : public Module Command *c = FindCommand(ChanServ, "SET"); if (c) - c->AddSubcommand(new CommandCSSetTopicLock("TOPICLOCK")); + c->AddSubcommand(&commandcssettopiclock); c = FindCommand(ChanServ, "SASET"); if (c) - c->AddSubcommand(new CommandCSSASetTopicLock("TOPICLOCK")); + c->AddSubcommand(&commandcssasettopiclock); } ~CSSetTopicLock() { Command *c = FindCommand(ChanServ, "SET"); if (c) - c->DelSubcommand("TOPICLOCK"); + c->DelSubcommand(&commandcssettopiclock); c = FindCommand(ChanServ, "SASET"); if (c) - c->DelSubcommand("TOPICLOCK"); + c->DelSubcommand(&commandcssasettopiclock); } }; |