X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_ircv3_servertime.cpp;h=3e059719d13ac6bac1f03b6cf5968912595fc9fc;hb=9acece70e533fc45d5401e331af25a5e99dab660;hp=1c35c422b041736781f99adb54893978550064a8;hpb=224952435591734d8308fd2b612d51c030416e53;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_ircv3_servertime.cpp b/src/modules/m_ircv3_servertime.cpp index 1c35c422b..3e059719d 100644 --- a/src/modules/m_ircv3_servertime.cpp +++ b/src/modules/m_ircv3_servertime.cpp @@ -20,20 +20,28 @@ #include "inspircd.h" #include "modules/ircv3.h" #include "modules/ircv3_servertime.h" +#include "modules/server.h" -class ServerTimeTag : public IRCv3::ServerTime::Manager, public IRCv3::CapTag +class ServerTimeTag + : public IRCv3::ServerTime::Manager + , public IRCv3::CapTag + , public ServerProtocol::MessageEventListener { time_t lasttime; + long lasttimens; std::string lasttimestring; void RefreshTimeString() { const time_t currtime = ServerInstance->Time(); - if (currtime != lasttime) + const long currtimens = ServerInstance->Time_ns(); + if (currtime != lasttime || currtimens != lasttimens) { lasttime = currtime; - // Cache the string so it's not recreated every time a message is sent - lasttimestring = IRCv3::ServerTime::FormatTime(currtime); + lasttimens = currtimens; + + // Cache the string so it's not recreated every time a message is sent. + lasttimestring = IRCv3::ServerTime::FormatTime(currtime, (currtimens ? currtimens / 1000000 : 0)); } } @@ -41,16 +49,27 @@ class ServerTimeTag : public IRCv3::ServerTime::Manager, public IRCv3::CapTag(mod, "server-time", "time") + , ServerProtocol::MessageEventListener(mod) , lasttime(0) + , lasttimens(0) { tagprov = this; } const std::string* GetValue(const ClientProtocol::Message& msg) { + // Client protocol. RefreshTimeString(); return &lasttimestring; } + + void OnBuildMessage(User* source, const char* command, ClientProtocol::TagMap& tags) CXX11_OVERRIDE + { + // Server protocol. + RefreshTimeString(); + tags.insert(std::make_pair(tagname, ClientProtocol::MessageTagData(this, lasttimestring))); + } + }; class ModuleIRCv3ServerTime : public Module