summaryrefslogtreecommitdiff
path: root/modules/core/ns_saset.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2010-07-31 21:37:45 -0400
committerAdam <Adam@anope.org>2010-07-31 21:37:45 -0400
commitc770c47e18121e93bcdd06b1ab5f161440ffcfe2 (patch)
tree8e80d54507ab705e2dc51278c533c6000c8af1da /modules/core/ns_saset.cpp
parent9d0d44d738705a457ce08599ba50c97033a43c71 (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.cpp26
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);
}
};