summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPeter Powell <petpow@saberuk.com>2019-06-25 15:03:03 +0100
committerPeter Powell <petpow@saberuk.com>2019-06-25 16:52:26 +0100
commit02beded762ccc71c7f87ec8bb32b8d614960ab90 (patch)
tree9c943a8dfefb31421edc9b8a7994c36aa4722d68 /src
parent30a651d0927228e4c0ccd2ec053e3ae08a8ae950 (diff)
Switch permchannels and xline_db from OnBackgroundTimer to a Timer.
Diffstat (limited to 'src')
-rw-r--r--src/modules/m_permchannels.cpp14
-rw-r--r--src/modules/m_xline_db.cpp15
2 files changed, 24 insertions, 5 deletions
diff --git a/src/modules/m_permchannels.cpp b/src/modules/m_permchannels.cpp
index 898d7aed8..4e365d0ab 100644
--- a/src/modules/m_permchannels.cpp
+++ b/src/modules/m_permchannels.cpp
@@ -156,7 +156,10 @@ static bool WriteDatabase(PermChannel& permchanmode, Module* mod, bool save_list
return true;
}
-class ModulePermanentChannels : public Module
+class ModulePermanentChannels
+ : public Module
+ , public Timer
+
{
PermChannel p;
bool dirty;
@@ -165,7 +168,10 @@ class ModulePermanentChannels : public Module
public:
ModulePermanentChannels()
- : p(this), dirty(false), loaded(false)
+ : Timer(0, true)
+ , p(this)
+ , dirty(false)
+ , loaded(false)
{
}
@@ -174,6 +180,7 @@ public:
ConfigTag* tag = ServerInstance->Config->ConfValue("permchanneldb");
permchannelsconf = tag->getString("filename");
save_listmodes = tag->getBool("listmodes");
+ SetInterval(tag->getDuration("saveperiod", 5));
if (!permchannelsconf.empty())
permchannelsconf = ServerInstance->Config->Paths.PrependConfig(permchannelsconf);
@@ -265,11 +272,12 @@ public:
dirty = true;
}
- void OnBackgroundTimer(time_t) CXX11_OVERRIDE
+ bool Tick(time_t) CXX11_OVERRIDE
{
if (dirty)
WriteDatabase(p, this, save_listmodes);
dirty = false;
+ return true;
}
void Prioritize() CXX11_OVERRIDE
diff --git a/src/modules/m_xline_db.cpp b/src/modules/m_xline_db.cpp
index 925024aea..00605f259 100644
--- a/src/modules/m_xline_db.cpp
+++ b/src/modules/m_xline_db.cpp
@@ -22,11 +22,20 @@
#include "xline.h"
#include <fstream>
-class ModuleXLineDB : public Module
+class ModuleXLineDB
+ : public Module
+ , public Timer
{
+ private:
bool dirty;
std::string xlinedbpath;
+
public:
+ ModuleXLineDB()
+ : Timer(0, true)
+ {
+ }
+
void init() CXX11_OVERRIDE
{
/* Load the configuration
@@ -37,6 +46,7 @@ class ModuleXLineDB : public Module
*/
ConfigTag* Conf = ServerInstance->Config->ConfValue("xlinedb");
xlinedbpath = ServerInstance->Config->Paths.PrependData(Conf->getString("filename", "xline.db"));
+ SetInterval(Conf->getDuration("saveperiod", 5));
// Read xlines before attaching to events
ReadDatabase();
@@ -66,13 +76,14 @@ class ModuleXLineDB : public Module
dirty = true;
}
- void OnBackgroundTimer(time_t now) CXX11_OVERRIDE
+ bool Tick(time_t) CXX11_OVERRIDE
{
if (dirty)
{
if (WriteDatabase())
dirty = false;
}
+ return true;
}
bool WriteDatabase()