X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fnetworkmodel.cpp;h=b5c21c41685df6cd57acd0529ba7986a0ce28352;hp=f5442be1d2dcfd6b7e3392d00e7d2df2bf2e45dd;hb=3a0953ec32f41214b5a86dc6e5c8fd5d8563c42c;hpb=6b31f4c8abb36ebe658c2e5ce2a8e9ba2a50f443 diff --git a/src/client/networkmodel.cpp b/src/client/networkmodel.cpp index f5442be1..b5c21c41 100644 --- a/src/client/networkmodel.cpp +++ b/src/client/networkmodel.cpp @@ -21,6 +21,7 @@ #include "networkmodel.h" #include +#include // for Qt::escape() #include "buffermodel.h" #include "client.h" @@ -107,6 +108,23 @@ BufferItem *NetworkItem::bufferItem(const BufferInfo &bufferInfo) { } newChild(bufferItem); + + // postprocess... this is necessary because Qt doesn't seem to like adding childs which already have childs on their own + switch(bufferInfo.type()) { + case BufferInfo::ChannelBuffer: + { + ChannelBufferItem *channelBufferItem = static_cast(bufferItem); + if(_network) { + IrcChannel *ircChannel = _network->ircChannel(bufferInfo.bufferName()); + if(ircChannel) + channelBufferItem->attachIrcChannel(ircChannel); + } + } + break; + default: + break; + } + return bufferItem; } @@ -174,8 +192,8 @@ void NetworkItem::setCurrentServer(const QString &serverName) { QString NetworkItem::toolTip(int column) const { Q_UNUSED(column); - QStringList toolTip(QString("%1").arg(networkName())); - toolTip.append(tr("Server: %1").arg(currentServer())); + QStringList toolTip(QString("%1").arg(Qt::escape(networkName()))); + toolTip.append(tr("Server: %1").arg(Qt::escape(currentServer()))); toolTip.append(tr("Users: %1").arg(nickCount())); if(_network) { @@ -447,13 +465,6 @@ ChannelBufferItem::ChannelBufferItem(const BufferInfo &bufferInfo, AbstractTreeI : BufferItem(bufferInfo, parent), _ircChannel(0) { - const Network *net = Client::network(bufferInfo.networkId()); - if(!net) - return; - - IrcChannel *ircChannel = net->ircChannel(bufferInfo.bufferName()); - if(ircChannel) - attachIrcChannel(ircChannel); } QVariant ChannelBufferItem::data(int column, int role) const { @@ -469,7 +480,7 @@ QString ChannelBufferItem::toolTip(int column) const { Q_UNUSED(column); QStringList toolTip; - toolTip.append(tr("Channel %1").arg(bufferName())); + toolTip.append(tr("Channel %1").arg(Qt::escape(bufferName()))); if(isActive()) { //TODO: add channel modes toolTip.append(tr("Users: %1").arg(nickCount())); @@ -485,8 +496,7 @@ QString ChannelBufferItem::toolTip(int column) const { QString _topic = topic(); if(_topic != "") { _topic = stripFormatCodes(_topic); - _topic.replace(QString("<"), QString("<")); - _topic.replace(QString(">"), QString(">")); + _topic = Qt::escape(_topic); toolTip.append(QString(" ")); toolTip.append(tr("Topic: %1").arg(_topic)); }