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/ns_saset.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/ns_saset.cpp')
-rw-r--r-- | modules/core/ns_saset.cpp | 26 |
1 files changed, 14 insertions, 12 deletions
diff --git a/modules/core/ns_saset.cpp b/modules/core/ns_saset.cpp index 624f25b7b..c42a1939f 100644 --- a/modules/core/ns_saset.cpp +++ b/modules/core/ns_saset.cpp @@ -19,14 +19,12 @@ class CommandNSSASet : public Command subcommand_map subcommands; public: - CommandNSSASet(const Anope::string &cname) : Command(cname, 2, 4) + CommandNSSASet() : Command("SASET", 2, 4) { } ~CommandNSSASet() { - for (subcommand_map::const_iterator it = this->subcommands.begin(), it_end = this->subcommands.end(); it != it_end; ++it) - delete it->second; this->subcommands.clear(); } @@ -102,9 +100,9 @@ class CommandNSSASet : public Command return this->subcommands.insert(std::make_pair(c->name, c)).second; } - bool DelSubcommand(const Anope::string &command) + bool DelSubcommand(Command *c) { - return this->subcommands.erase(command); + return this->subcommands.erase(c->name); } Command *FindCommand(const Anope::string &subcommand) @@ -121,7 +119,7 @@ class CommandNSSASet : public Command class CommandNSSASetDisplay : public Command { public: - CommandNSSASetDisplay(const Anope::string &cname) : Command(cname, 2, 2, "nickserv/saset/display") + CommandNSSASetDisplay() : Command("DISPLAY", 2, 2, "nickserv/saset/display") { } @@ -164,7 +162,7 @@ class CommandNSSASetDisplay : public Command class CommandNSSASetPassword : public Command { public: - CommandNSSASetPassword(const Anope::string &cname) : Command(cname, 2, 2, "nickserv/saset/password") + CommandNSSASetPassword() : Command("PASSWORD", 2, 2, "nickserv/saset/password") { } @@ -232,16 +230,20 @@ class CommandNSSASetPassword : public Command class NSSASet : public Module { -public: + CommandNSSASet commandnssaset; + CommandNSSASetDisplay commandnssasetdisplay; + CommandNSSASetPassword commandnssasetpassword; + + public: NSSASet(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator) { this->SetAuthor("Anope"); this->SetType(CORE); - Command *c = new CommandNSSASet("SASET"); - this->AddCommand(NickServ, c); - c->AddSubcommand(new CommandNSSASetDisplay("DISPLAY")); - c->AddSubcommand(new CommandNSSASetPassword("PASSWORD")); + this->AddCommand(NickServ, &commandnssaset); + + commandnssaset.AddSubcommand(&commandnssasetdisplay); + commandnssaset.AddSubcommand(&commandnssasetpassword); } }; |