X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=5f03d9d09a74b52cf363cecbb38c9b10c2913c76;hp=6e4982a4edb7bf75c354364c24b6e0eeec8180a6;hb=8301c4e1ac95ae0462f91cc0e4a90ba2efa5cc45;hpb=65c657b9339661b5ba31f132c914873f4a9093ae diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index 6e4982a4..5f03d9d0 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -35,6 +35,8 @@ ChatLine::ChatLine(const QModelIndex &index, QGraphicsItem *parent) : QGraphicsI _timestampItem->setPos(0,0); _width = _height = 0; _selection = 0; + + if(_contentsItem->data(MessageModel::FlagsRole).toInt() & Message::Highlight) setHighlighted(true); } ChatLine::~ChatLine() { @@ -75,15 +77,21 @@ qreal ChatLine::setGeometry(qreal width, qreal firstHandlePos, qreal secondHandl void ChatLine::setSelected(bool selected, ChatLineModel::ColumnType minColumn) { if(selected) { - _selection = (_selection & 0x80) | 0x40 | minColumn; - for(int i = 0; i < minColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); - for(int i = minColumn; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->setFullSelection(); - } - else { - _selection &= 0x80; - for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + quint8 sel = (_selection & 0x80) | 0x40 | minColumn; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i < minColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + for(int i = minColumn; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->setFullSelection(); + update(); + } + } else { + quint8 sel = _selection & 0x80; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) item((ChatLineModel::ColumnType)i)->clearSelection(); + update(); + } } - update(); } void ChatLine::setHighlighted(bool highlighted) {