X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fircparser.cpp;h=3be0a3fedaff4ab51ca3a794026f3a6e332a928c;hp=2add78d7a689a255297ee4dcbd125c5b97737f48;hb=8dfdd498679c773cf2e7958c5fd434bf56f634e3;hpb=edc55b1f86cf613a332eeeb5d85537a54120dfa5 diff --git a/src/core/ircparser.cpp b/src/core/ircparser.cpp index 2add78d7..3be0a3fe 100644 --- a/src/core/ircparser.cpp +++ b/src/core/ircparser.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2019 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -119,6 +119,17 @@ void IrcParser::processNetworkIncoming(NetworkDataEvent* e) qDebug() << "IRC net" << net->networkId() << "<<" << tags << prefix << cmd << params; } + IrcTagKey serverTimeTag{"", "time", false}; + if (tags.contains(serverTimeTag)) { + QDateTime serverTime = QDateTime::fromString(tags[serverTimeTag], "yyyy-MM-ddThh:mm:ss.zzzZ"); + serverTime.setTimeSpec(Qt::UTC); + if (serverTime.isValid()) { + e->setTimestamp(serverTime); + } else { + qDebug() << "Invalid timestamp from server-time tag:" << tags[serverTimeTag]; + } + } + QList events; EventManager::EventType type = EventManager::Invalid;