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_peace.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_peace.cpp')
-rw-r--r-- | modules/core/cs_set_peace.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/modules/core/cs_set_peace.cpp b/modules/core/cs_set_peace.cpp index aa058b416..f8c21132a 100644 --- a/modules/core/cs_set_peace.cpp +++ b/modules/core/cs_set_peace.cpp @@ -16,7 +16,7 @@ class CommandCSSetPeace : public Command { public: - CommandCSSetPeace(const Anope::string &cname, const Anope::string &cpermission = "") : Command(cname, 2, 2, cpermission) + CommandCSSetPeace(const Anope::string &cpermission = "") : Command("PEACE", 2, 2, cpermission) { } @@ -62,7 +62,7 @@ class CommandCSSetPeace : public Command class CommandCSSASetPeace : public CommandCSSetPeace { public: - CommandCSSASetPeace(const Anope::string &cname) : CommandCSSetPeace(cname, "chanserv/saset/peace") + CommandCSSASetPeace() : CommandCSSetPeace("chanserv/saset/peace") { } @@ -80,6 +80,9 @@ class CommandCSSASetPeace : public CommandCSSetPeace class CSSetPeace : public Module { + CommandCSSetPeace commandcssetpeace; + CommandCSSASetPeace commandcssasetpeace; + public: CSSetPeace(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator) { @@ -88,22 +91,22 @@ class CSSetPeace : public Module Command *c = FindCommand(ChanServ, "SET"); if (c) - c->AddSubcommand(new CommandCSSetPeace("PEACE")); + c->AddSubcommand(&commandcssetpeace); c = FindCommand(ChanServ, "SASET"); if (c) - c->AddSubcommand(new CommandCSSASetPeace("PEACE")); + c->AddSubcommand(&commandcssasetpeace); } ~CSSetPeace() { Command *c = FindCommand(ChanServ, "SET"); if (c) - c->DelSubcommand("PEACE"); + c->DelSubcommand(&commandcssetpeace); c = FindCommand(ChanServ, "SASET"); if (c) - c->DelSubcommand("PEACE"); + c->DelSubcommand(&commandcssasetpeace); } }; |