X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fmessage.cpp;h=797dfbbfbdc9a71071417c70fc77a073b34eb19c;hp=837dc35a593922b7ae2dc3d43e00bccea8dbcc52;hb=902c95728306e5ba115de84800fc8d5d239c9d62;hpb=2039f5e28eeb431e394f1c2468a26218bd926538 diff --git a/src/common/message.cpp b/src/common/message.cpp index 837dc35a..797dfbbf 100644 --- a/src/common/message.cpp +++ b/src/common/message.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005/06 by The Quassel Team * + * Copyright (C) 2005-07 by the Quassel IRC Development Team * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -19,11 +19,143 @@ ***************************************************************************/ #include "message.h" + +#include "util.h" + #include +Message::Message(BufferInfo __buffer, Type __type, QString __text, QString __sender, quint8 __flags) + : _buffer(__buffer), _text(__text), _sender(__sender), _type(__type), _flags(__flags) { + _timeStamp = QDateTime::currentDateTime().toUTC(); +} + +Message::Message(QDateTime __ts, BufferInfo __buffer, Type __type, QString __text, QString __sender, quint8 __flags) + : _timeStamp(__ts), _buffer(__buffer), _text(__text), _sender(__sender), _type(__type), _flags(__flags) { + +} + +MsgId Message::msgId() const { + return _msgId; +} + +void Message::setMsgId(MsgId _id) { + _msgId = _id; +} + +BufferInfo Message::buffer() const { + return _buffer; +} + +QString Message::text() const { + return _text; +} + +QString Message::sender() const { + return _sender; +} + +Message::Type Message::type() const { + return _type; +} + +quint8 Message::flags() const { + return _flags; +} + +QDateTime Message::timeStamp() const { + return _timeStamp; +} + +QString Message::mircToInternal(QString mirc) { + mirc.replace('%', "%%"); // escape % just to be sure + mirc.replace('\x02', "%B"); + mirc.replace('\x03', "%C"); + mirc.replace('\x0f', "%O"); + mirc.replace('\x12', "%R"); + mirc.replace('\x16', "%R"); + mirc.replace('\x1d', "%S"); + mirc.replace('\x1f', "%U"); + return mirc; +} + +void Message::format() { + if(!_formattedText.isNull()) return; // already done + QString user = userFromMask(sender()); + QString host = hostFromMask(sender()); + QString nick = nickFromMask(sender()); + QString txt = mircToInternal(text()); + QString networkName = buffer().network(); + QString bufferName = buffer().buffer(); + + _formattedTimeStamp = tr("%DT[%1]").arg(timeStamp().toLocalTime().toString("hh:mm:ss")); + + QString s, t; + switch(type()) { + case Message::Plain: + s = tr("%DS<%1>").arg(nick); t = tr("%D0%1").arg(txt); break; + case Message::Server: + s = tr("%Ds*"); t = tr("%Ds%1").arg(txt); break; + case Message::Error: + s = tr("%De*"); t = tr("%De%1").arg(txt); break; + case Message::Join: + s = tr("%Dj-->"); t = tr("%Dj%DN%DU%1%DU%DN %DH(%2@%3)%DH has joined %DC%DU%4%DU%DC").arg(nick, user, host, bufferName); break; + case Message::Part: + s = tr("%Dp<--"); t = tr("%Dp%DN%DU%1%DU%DN %DH(%2@%3)%DH has left %DC%DU%4%DU%DC").arg(nick, user, host, bufferName); + if(!txt.isEmpty()) t = QString("%1 (%2)").arg(t).arg(txt); + break; + case Message::Quit: + s = tr("%Dq<--"); t = tr("%Dq%DN%DU%1%DU%DN %DH(%2@%3)%DH has quit").arg(nick, user, host); + if(!txt.isEmpty()) t = QString("%1 (%2)").arg(t).arg(txt); + break; + case Message::Kick: + { s = tr("%Dk<-*"); + QString victim = txt.section(" ", 0, 0); + //if(victim == ui.ownNick->currentText()) victim = tr("you"); + QString kickmsg = txt.section(" ", 1); + t = tr("%Dk%DN%DU%1%DU%DN has kicked %DN%DU%2%DU%DN from %DC%DU%3%DU%DC").arg(nick).arg(victim).arg(bufferName); + if(!kickmsg.isEmpty()) t = QString("%1 (%2)").arg(t).arg(kickmsg); + } + break; + case Message::Nick: + s = tr("%Dr<->"); + if(nick == text()) t = tr("%DrYou are now known as %DN%1%DN").arg(text()); + else t = tr("%Dr%DN%1%DN is now known as %DN%DU%2%DU%DN").arg(nick, text()); + break; + case Message::Mode: + s = tr("%Dm***"); + if(nick.isEmpty()) t = tr("%DmUser mode: %DM%1%DM").arg(text()); + else t = tr("%DmMode %DM%1%DM by %DN%DU%2%DU%DN").arg(text(), nick); + break; + case Message::Action: + s = tr("%Da-*-"); + t = tr("%Da%DN%DU%1%DU%DN %2").arg(nick).arg(text()); + break; + default: + s = tr("%De%1").arg(sender()); + t = tr("%De[%1]").arg(text()); + } + _formattedSender = s; + _formattedText = t; +} + +QString Message::formattedTimeStamp() { + format(); + return _formattedTimeStamp; +} + +QString Message::formattedSender() { + format(); + return _formattedSender; +} + +QString Message::formattedText() { + format(); + return _formattedText; +} + QDataStream &operator<<(QDataStream &out, const Message &msg) { - out << (quint32)msg.timeStamp.toTime_t() << (quint8)msg.type << (quint8)msg.flags - << msg.buffer << msg.sender.toUtf8() << msg.text.toUtf8(); + out << (quint32)msg.timeStamp().toTime_t() << (quint8)msg.type() << (quint8)msg.flags() + << msg.buffer() << msg.sender().toUtf8() << msg.text().toUtf8(); return out; } @@ -31,14 +163,14 @@ QDataStream &operator>>(QDataStream &in, Message &msg) { quint8 t, f; quint32 ts; QByteArray s, m; - BufferId buf; + BufferInfo buf; in >> ts >> t >> f >> buf >> s >> m; - msg.type = (Message::Type)t; - msg.flags = (quint8)f; - msg.buffer = buf; - msg.timeStamp = QDateTime::fromTime_t(ts); - msg.sender = QString::fromUtf8(s); - msg.text = QString::fromUtf8(m); + msg._type = (Message::Type)t; + msg._flags = (quint8)f; + msg._buffer = buf; + msg._timeStamp = QDateTime::fromTime_t(ts); + msg._sender = QString::fromUtf8(s); + msg._text = QString::fromUtf8(m); return in; }