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_xop.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_xop.cpp')
-rw-r--r-- | modules/core/cs_set_xop.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/modules/core/cs_set_xop.cpp b/modules/core/cs_set_xop.cpp index c7d4017b0..1c4c2f431 100644 --- a/modules/core/cs_set_xop.cpp +++ b/modules/core/cs_set_xop.cpp @@ -17,7 +17,7 @@ class CommandCSSetXOP : public Command { public: - CommandCSSetXOP(const Anope::string &cname, const Anope::string &cpermission = "") : Command(cname, 2, 2, cpermission) + CommandCSSetXOP(const Anope::string &cpermission = "") : Command("XOP", 2, 2, cpermission) { } @@ -100,7 +100,7 @@ class CommandCSSetXOP : public Command class CommandCSSASetXOP : public CommandCSSetXOP { public: - CommandCSSASetXOP(const Anope::string &cname) : CommandCSSetXOP(cname, "chanserv/saset/xop") + CommandCSSASetXOP() : CommandCSSetXOP("chanserv/saset/xop") { } @@ -118,6 +118,9 @@ class CommandCSSASetXOP : public CommandCSSetXOP class CSSetXOP : public Module { + CommandCSSetXOP commandcssetxop; + CommandCSSASetXOP commandcssasetxop; + public: CSSetXOP(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator) { @@ -126,22 +129,22 @@ class CSSetXOP : public Module Command *c = FindCommand(ChanServ, "SET"); if (c) - c->AddSubcommand(new CommandCSSetXOP("XOP")); + c->AddSubcommand(&commandcssetxop); c = FindCommand(ChanServ, "SASET"); if (c) - c->AddSubcommand(new CommandCSSASetXOP("XOP")); + c->AddSubcommand(&commandcssasetxop); } ~CSSetXOP() { Command *c = FindCommand(ChanServ, "SET"); if (c) - c->DelSubcommand("XOP"); + c->DelSubcommand(&commandcssetxop); c = FindCommand(ChanServ, "SASET"); if (c) - c->DelSubcommand("XOP"); + c->DelSubcommand(&commandcssasetxop); } }; |