From 2630a87bb13b089e6d0fdcff4bcd0f3a9612e52f Mon Sep 17 00:00:00 2001 From: danieldg Date: Wed, 2 Sep 2009 00:43:04 +0000 Subject: Change allocation of commands/modes API change: Commands passed to AddCommand are no longer deleted automatically This removes lots of needless heap allocation and fixes a few memory leaks by allocating commands and modes as part of the Module rather than creating them separately in the module constructor. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11592 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_lockserv.cpp | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) (limited to 'src/modules/m_lockserv.cpp') diff --git a/src/modules/m_lockserv.cpp b/src/modules/m_lockserv.cpp index f25ba0553..77dc5a219 100644 --- a/src/modules/m_lockserv.cpp +++ b/src/modules/m_lockserv.cpp @@ -71,8 +71,8 @@ class ModuleLockserv : public Module { private: bool locked; - CommandLockserv* lockcommand; - CommandUnlockserv* unlockcommand; + CommandLockserv lockcommand; + CommandUnlockserv unlockcommand; virtual void ResetLocked() { @@ -80,14 +80,11 @@ private: } public: - ModuleLockserv(InspIRCd* Me) : Module(Me) + ModuleLockserv(InspIRCd* Me) : Module(Me), lockcommand(Me, locked), unlockcommand(Me, locked) { ResetLocked(); - lockcommand = new CommandLockserv(ServerInstance, locked); - ServerInstance->AddCommand(lockcommand); - - unlockcommand = new CommandUnlockserv(ServerInstance, locked); - ServerInstance->AddCommand(unlockcommand); + ServerInstance->AddCommand(&lockcommand); + ServerInstance->AddCommand(&unlockcommand); Implementation eventlist[] = { I_OnUserRegister, I_OnRehash, I_OnCheckReady }; ServerInstance->Modules->Attach(eventlist, this, 3); } -- cgit v1.2.3