X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fclient%2Fclient.cpp;h=4d716ed044e653b3a1a74716aeb46a63a9def7b5;hb=dd24b914045d1b38d8ae5347158aa2266166703b;hp=9e22ce0867e8b4d0c4df083e9ca833c6aa3d996d;hpb=ee6e4f90ce63d7eb3a54937cffb33510398d2349;p=quassel.git diff --git a/src/client/client.cpp b/src/client/client.cpp index 9e22ce08..4d716ed0 100644 --- a/src/client/client.cpp +++ b/src/client/client.cpp @@ -76,6 +76,8 @@ void Client::init() { _networkModel = new NetworkModel(this); connect(this, SIGNAL(bufferUpdated(BufferInfo)), _networkModel, SLOT(bufferUpdated(BufferInfo))); + connect(this, SIGNAL(networkRemoved(NetworkId)), + _networkModel, SLOT(networkRemoved(NetworkId))); _bufferModel = new BufferModel(_networkModel); @@ -379,11 +381,24 @@ void Client::networkDestroyed() { } } -void Client::recvMessage(const Message &msg) { - Buffer *b = buffer(msg.bufferInfo()); +void Client::recvMessage(const Message &message) { + Message msg = message; + Buffer *b; + + if(msg.type() == Message::Error) { + b = buffer(msg.bufferInfo().bufferId()); + if(!b) { + // FIXME: if buffer doesn't exist, forward the message to the status or current buffer + b = buffer(msg.bufferInfo()); + } + } else { + b = buffer(msg.bufferInfo()); + } + + checkForHighlight(msg); b->appendMsg(msg); networkModel()->updateBufferActivity(msg); - + if(msg.type() == Message::Plain || msg.type() == Message::Notice || msg.type() == Message::Action) { const Network *net = network(msg.bufferInfo().networkId()); QString networkName = net != 0 @@ -404,8 +419,9 @@ void Client::recvBacklogData(BufferInfo id, QVariantList msgs, bool /*done*/) { Buffer *b = buffer(id); foreach(QVariant v, msgs) { Message msg = v.value(); + checkForHighlight(msg); b->prependMsg(msg); - // networkModel()->updateBufferActivity(msg); + networkModel()->updateBufferActivity(msg); if(!layoutQueue.contains(b)) layoutQueue.append(b); } if(layoutQueue.count() && !layoutTimer->isActive()) layoutTimer->start(); @@ -426,3 +442,11 @@ AbstractUiMsg *Client::layoutMsg(const Message &msg) { return instance()->mainUi->layoutMsg(msg); } +void Client::checkForHighlight(Message &msg) const { + const Network *net = network(msg.bufferInfo().networkId()); + if(net && !net->myNick().isEmpty()) { + QRegExp nickRegExp("^(.*\\W)?" + QRegExp::escape(net->myNick()) + "(\\W.*)?$"); + if((msg.type() & (Message::Plain | Message::Notice | Message::Action)) && nickRegExp.exactMatch(msg.text())) + msg.setFlags(msg.flags() | Message::Highlight); + } +}