X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fmessageevent.cpp;h=1befbbd70adeba3b916ce8c9789264e638dec9e7;hp=d7f3b7c910ee73faa28d7f6b60d61b2cce926234;hb=c27d5bfbe80bfeb583a25404f4ccee4b70b010e0;hpb=6097f67231950c4c22845735db8b997a844fec48 diff --git a/src/common/messageevent.cpp b/src/common/messageevent.cpp index d7f3b7c9..1befbbd7 100644 --- a/src/common/messageevent.cpp +++ b/src/common/messageevent.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2010 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,39 +15,78 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "messageevent.h" +Event *MessageEvent::create(EventManager::EventType type, QVariantMap &map, Network *network) +{ + if (type == EventManager::MessageEvent) + return new MessageEvent(type, map, network); + + return 0; +} + -MessageEvent::MessageEvent(Message::Type msgType, Network *net, const QString &msg, const QString &target, const QString &sender, Message::Flags flags) +MessageEvent::MessageEvent(Message::Type msgType, Network *net, const QString &msg, const QString &sender, const QString &target, + Message::Flags flags, const QDateTime ×tamp) : NetworkEvent(EventManager::MessageEvent, net), - _msgType(msgType), - _text(msg), - _target(target), - _sender(sender), - _msgFlags(flags) + _msgType(msgType), + _text(msg), + _sender(sender), + _target(target), + _msgFlags(flags) { - IrcChannel *channel = network()->ircChannel(_target); - if(!channel) { - if(!_target.isEmpty() && network()->prefixes().contains(_target.at(0))) - _target = _target.mid(1); + IrcChannel *channel = network()->ircChannel(_target); + if (!channel) { + if (!_target.isEmpty() && network()->prefixes().contains(_target.at(0))) + _target = _target.mid(1); - if(_target.startsWith('$') || _target.startsWith('#')) - _target = nickFromMask(sender); - } + if (_target.startsWith('$') || _target.startsWith('#')) + _target = nickFromMask(sender); + } - _bufferType = bufferTypeByTarget(_target); + _bufferType = bufferTypeByTarget(_target); + + if (timestamp.isValid()) + setTimestamp(timestamp); + else + setTimestamp(QDateTime::currentDateTime()); } -BufferInfo::Type MessageEvent::bufferTypeByTarget(const QString &target) const { - if(target.isEmpty()) - return BufferInfo::StatusBuffer; - if(network()->isChannelName(target)) - return BufferInfo::ChannelBuffer; +MessageEvent::MessageEvent(EventManager::EventType type, QVariantMap &map, Network *network) + : NetworkEvent(type, map, network) +{ + _msgType = static_cast(map.take("messageType").toInt()); + _msgFlags = static_cast(map.take("messageFlags").toInt()); + _bufferType = static_cast(map.take("bufferType").toInt()); + _text = map.take("text").toString(); + _sender = map.take("sender").toString(); + _target = map.take("target").toString(); +} + - return BufferInfo::QueryBuffer; +void MessageEvent::toVariantMap(QVariantMap &map) const +{ + NetworkEvent::toVariantMap(map); + map["messageType"] = msgType(); + map["messageFlags"] = (int)msgFlags(); + map["bufferType"] = bufferType(); + map["text"] = text(); + map["sender"] = sender(); + map["target"] = target(); } + +BufferInfo::Type MessageEvent::bufferTypeByTarget(const QString &target) const +{ + if (target.isEmpty()) + return BufferInfo::StatusBuffer; + + if (network()->isChannelName(target)) + return BufferInfo::ChannelBuffer; + + return BufferInfo::QueryBuffer; +}