diff options
author | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-04-04 15:09:46 +0000 |
---|---|---|
committer | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-04-04 15:09:46 +0000 |
commit | bb1140e2da4f2d166a9a919f24e596a440dc4df5 (patch) | |
tree | 827baa2a42507c1507345bc7b6ac67821bd61214 /src/modules/m_chanlog.cpp | |
parent | 89fc6ca9c66198fe54cce19d59279cd454fc1bd0 (diff) |
Fix chanlog (NOTE: previous commit will require a FULL recompile)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9315 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/m_chanlog.cpp')
-rw-r--r-- | src/modules/m_chanlog.cpp | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/modules/m_chanlog.cpp b/src/modules/m_chanlog.cpp index 4a8a41cb0..a5fcbe5bf 100644 --- a/src/modules/m_chanlog.cpp +++ b/src/modules/m_chanlog.cpp @@ -51,6 +51,10 @@ class ModuleChanLog : public Module public: ModuleChanLog(InspIRCd* Me) : Module(Me) { + Implementation eventlist[] = { I_OnRehash }; + ServerInstance->Modules->Attach(eventlist, this, 1); + + OnRehash(NULL, ""); } virtual ~ModuleChanLog() @@ -63,23 +67,25 @@ class ModuleChanLog : public Module } } - virtual void OnReadConfig(ServerConfig* sc, ConfigReader* Conf) + virtual void OnRehash(User *user, const std::string ¶meter) { + ConfigReader Conf(ServerInstance); + /* Since the CloseLogs prior to this hook just wiped out our logstreams for us, we just need to wipe the vector. */ std::vector<ChannelLogStream*>().swap(cls); - int index, max = Conf->Enumerate("log"); + int index, max = Conf.Enumerate("log"); cls.reserve(max); for (index = 0; index < max; ++index) { - std::string method = Conf->ReadValue("log", "method", index); + std::string method = Conf.ReadValue("log", "method", index); //if (method != "file") // continue; - std::string type = Conf->ReadValue("log", "type", index); - std::string level = Conf->ReadValue("log", "level", index); + std::string type = Conf.ReadValue("log", "type", index); + std::string level = Conf.ReadValue("log", "level", index); int loglevel = DEFAULT; if (level == "debug") @@ -104,7 +110,7 @@ class ModuleChanLog : public Module loglevel = NONE; } - std::string target = Conf->ReadValue("log", "target", index); + std::string target = Conf.ReadValue("log", "target", index); printf("looking at tag with method: %s type: %s level: %s target: %s", method.c_str(), type.c_str(), level.c_str(), target.c_str()); |