diff options
author | Peter Powell <petpow@saberuk.com> | 2019-06-25 15:03:03 +0100 |
---|---|---|
committer | Peter Powell <petpow@saberuk.com> | 2019-06-25 16:52:26 +0100 |
commit | 02beded762ccc71c7f87ec8bb32b8d614960ab90 (patch) | |
tree | 9c943a8dfefb31421edc9b8a7994c36aa4722d68 /src/modules/m_permchannels.cpp | |
parent | 30a651d0927228e4c0ccd2ec053e3ae08a8ae950 (diff) |
Switch permchannels and xline_db from OnBackgroundTimer to a Timer.
Diffstat (limited to 'src/modules/m_permchannels.cpp')
-rw-r--r-- | src/modules/m_permchannels.cpp | 14 |
1 files changed, 11 insertions, 3 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 |