From 84af2151d56be3ad799a09143e8ac2cad4388ca0 Mon Sep 17 00:00:00 2001 From: Manuel Nickschas Date: Thu, 8 May 2008 18:07:07 +0000 Subject: [PATCH] code_duplication-- --- src/qtui/chatlinemodelitem.cpp | 36 ++++++++++++++++++++-------------- src/qtui/chatlinemodelitem.h | 8 +++++++- src/uisupport/uistyle.cpp | 2 +- 3 files changed, 29 insertions(+), 17 deletions(-) diff --git a/src/qtui/chatlinemodelitem.cpp b/src/qtui/chatlinemodelitem.cpp index dbd5e933..807d40c8 100644 --- a/src/qtui/chatlinemodelitem.cpp +++ b/src/qtui/chatlinemodelitem.cpp @@ -24,28 +24,34 @@ #include "uistyle.h" ChatlineModelItem::ChatlineModelItem(const Message &msg) : MessageModelItem(msg) { - _msg = QtUi::style()->styleMessage(msg); + QtUiStyle::StyledMessage m = QtUi::style()->styleMessage(msg); + + _timestamp.plainText = m.timestamp.text; + _sender.plainText = m.sender.text; + _contents.plainText = m.text.text; + + _timestamp.formatList = m.timestamp.formats; + _sender.formatList = m.sender.formats; + _contents.formatList = m.text.formats; } QVariant ChatlineModelItem::data(int column, int role) const { + const ChatlinePart *part; + + switch(column) { + case ChatlineModel::TimestampColumn: part = &_timestamp; break; + case ChatlineModel::SenderColumn: part = &_sender; break; + case ChatlineModel::TextColumn: part = &_contents; break; + default: return MessageModelItem::data(column, role); + } + switch(role) { - case ChatlineModel::DisplayRole: - switch(column) { - case ChatlineModel::TimestampColumn: return _msg.timestamp.text; - case ChatlineModel::SenderColumn: return _msg.sender.text; - case ChatlineModel::TextColumn: return _msg.text.text; - } - break; - case ChatlineModel::FormatRole: - switch(column) { - case ChatlineModel::TimestampColumn: return QVariant::fromValue(_msg.timestamp.formats); - case ChatlineModel::SenderColumn: return QVariant::fromValue(_msg.sender.formats); - case ChatlineModel::TextColumn: return QVariant::fromValue(_msg.text.formats); - } - break; + case ChatlineModel::DisplayRole: return part->plainText; + case ChatlineModel::FormatRole: return QVariant::fromValue(part->formatList); } + return MessageModelItem::data(column, role); } diff --git a/src/qtui/chatlinemodelitem.h b/src/qtui/chatlinemodelitem.h index 6256dc2e..4d5469e5 100644 --- a/src/qtui/chatlinemodelitem.h +++ b/src/qtui/chatlinemodelitem.h @@ -34,7 +34,13 @@ class ChatlineModelItem : public MessageModelItem { virtual bool setData(int column, const QVariant &value, int role); private: - UiStyle::StyledMessage _msg; + struct ChatlinePart { + QString plainText; + UiStyle::FormatList formatList; + + }; + + ChatlinePart _timestamp, _sender, _contents; }; #endif diff --git a/src/uisupport/uistyle.cpp b/src/uisupport/uistyle.cpp index a799d335..e0af5b15 100644 --- a/src/uisupport/uistyle.cpp +++ b/src/uisupport/uistyle.cpp @@ -25,7 +25,7 @@ UiStyle::UiStyle(const QString &settingsKey) : _settingsKey(settingsKey) { // register FormatList if that hasn't happened yet - // FIXME I don't think this actually avoids double registration... :/ + // FIXME I don't think this actually avoids double registration... then again... does it hurt? if(QVariant::nameToType("UiStyle::FormatList") == QVariant::Invalid) { qRegisterMetaType("UiStyle::FormatList"); qRegisterMetaTypeStreamOperators("UiStyle::FormatList"); -- 2.20.1