- } else {
- // the regular case: we can deliver where it was supposed to go
- b = buffer(msg.bufferInfo());
- b->appendMsg(msg);
- }
-
- //bufferModel()->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
- ? net->networkName() + ":"
- : QString();
- QString sender = networkName + msg.bufferInfo().bufferName() + ":" + msg.sender();
- Message mmsg = Message(msg.timestamp(), msg.bufferInfo(), msg.type(), msg.text(), sender, msg.flags());
- monitorBuffer()->appendMsg(mmsg);
- }
-}
-
-void Client::recvStatusMsg(QString /*net*/, QString /*msg*/) {
- //recvMessage(net, Message::server("", QString("[STATUS] %1").arg(msg)));
-}
-
-void Client::recvBacklogData(BufferInfo id, QVariantList msgs, bool /*done*/) {
- Buffer *b = buffer(id);
- if(!b) {
- qWarning() << "Client::recvBacklogData(): received Backlog for unknown Buffer:" << id;
- return;
- }
-
- foreach(QVariant v, msgs) {
- Message msg = v.value<Message>();
- checkForHighlight(msg);
- b->prependMsg(msg);
- //networkModel()->updateBufferActivity(msg);
- if(!layoutQueue.contains(b)) layoutQueue.append(b);
- }
- if(layoutQueue.count() && !layoutTimer->isActive()) layoutTimer->start();
-}
-
-void Client::layoutMsg() {
- if(layoutQueue.count()) {
- Buffer *b = layoutQueue.takeFirst(); // TODO make this the current buffer
- if(b->layoutMsg())
- layoutQueue.append(b); // Buffer has more messages in its queue --> Round Robin
- }
-
- if(!layoutQueue.count())
- layoutTimer->stop();
-}
-
-AbstractUiMsg *Client::layoutMsg(const Message &msg) {
- return instance()->mainUi->layoutMsg(msg);
-}
-
-void Client::checkForHighlight(Message &msg) {
- 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);
- }
-}
-
-void Client::updateLastSeen(BufferId id, const QDateTime &lastSeen) {
- Buffer *b = buffer(id);
- if(!b) {
- qWarning() << "Client::updateLastSeen(): Unknown buffer" << id;
- return;
- }
- b->setLastSeen(lastSeen);
-}
-
-void Client::setBufferLastSeen(BufferId id, const QDateTime &lastSeen) {
- if(!bufferSyncer()) return;
- bufferSyncer()->requestSetLastSeen(id, lastSeen);
-}
-
-void Client::removeBuffer(BufferId id) {
- if(!bufferSyncer()) return;
- bufferSyncer()->requestRemoveBuffer(id);
-}
-
-void Client::bufferRemoved(BufferId bufferId) {
- QModelIndex current = bufferModel()->currentIndex();
- if(current.data(NetworkModel::BufferIdRole).value<BufferId>() == bufferId) {
- // select the status buffer if the currently displayed buffer is about to be removed
- bufferModel()->setCurrentIndex(current.sibling(0,0));
- }
-
- networkModel()->removeBuffer(bufferId);
- if(_buffers.contains(bufferId)) {
- Buffer *buff = _buffers.take(bufferId);
- disconnect(buff, 0, this, 0);
- buff->deleteLater();
- }
-}
-
-void Client::bufferRenamed(BufferId bufferId, const QString &newName) {
- QModelIndex bufferIndex = networkModel()->bufferIndex(bufferId);
- if(bufferIndex.isValid()) {
- networkModel()->setData(bufferIndex, newName, Qt::DisplayRole);
- }