clazy: Convert many old-style connects into function pointer based
[quassel.git] / src / qtui / chatlinemodel.cpp
index 28d77fb..477643c 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-08 by the Quassel IRC Team                         *
+ *   Copyright (C) 2005-2018 by the Quassel Project                        *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
  *   You should have received a copy of the GNU General Public License     *
  *   along with this program; if not, write to the                         *
  *   Free Software Foundation, Inc.,                                       *
- *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
+ *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         *
  ***************************************************************************/
 
 #include "chatlinemodel.h"
+#include "qtui.h"
+#include "qtuistyle.h"
 
-#include "chatlinemodelitem.h"
-
-ChatLineModel::ChatLineModel(QObject *parent) : MessageModel(parent) {
-  qRegisterMetaType<WrapList>("ChatLineModel::WrapList");
-  qRegisterMetaTypeStreamOperators<WrapList>("ChatLineModel::WrapList");
+ChatLineModel::ChatLineModel(QObject *parent)
+    : MessageModel(parent)
+{
+    qRegisterMetaType<WrapList>("ChatLineModel::WrapList");
+    qRegisterMetaTypeStreamOperators<WrapList>("ChatLineModel::WrapList");
 
+    connect(QtUi::style(), &UiStyle::changed, this, &ChatLineModel::styleChanged);
 }
 
-ChatLineModel::~ChatLineModel() {
 
+// MessageModelItem *ChatLineModel::createMessageModelItem(const Message &msg) {
+//   return new ChatLineModelItem(msg);
+// }
+
+void ChatLineModel::insertMessages__(int pos, const QList<Message> &messages)
+{
+    for (int i = 0; i < messages.count(); i++) {
+        _messageList.insert(pos, ChatLineModelItem(messages[i]));
+        pos++;
+    }
 }
 
 
-MessageModelItem *ChatLineModel::createMessageModelItem(const Message &msg) {
-  return new ChatLineModelItem(msg);
+Message ChatLineModel::takeMessageAt(int i)
+{
+    Message msg = _messageList[i].message();
+    _messageList.removeAt(i);
+    return msg;
+}
 
+
+void ChatLineModel::styleChanged()
+{
+    foreach(ChatLineModelItem item, _messageList) {
+        item.invalidateWrapList();
+    }
+    emit dataChanged(index(0, 0), index(rowCount()-1, columnCount()-1));
 }
 
 
-QDataStream &operator<<(QDataStream &out, const ChatLineModel::WrapList wplist) {
-  out << wplist.count();
-  ChatLineModel::WrapList::const_iterator it = wplist.begin();
-  while(it != wplist.end()) {
-    out << (*it).start << (*it).width << (*it).trailing;
-    ++it;
-  }
-  return out;
+QDataStream &operator<<(QDataStream &out, const ChatLineModel::WrapList wplist)
+{
+    out << wplist.count();
+    ChatLineModel::WrapList::const_iterator it = wplist.begin();
+    while (it != wplist.end()) {
+        out << (*it).start << (*it).width << (*it).trailing;
+        ++it;
+    }
+    return out;
 }
 
-QDataStream &operator>>(QDataStream &in, ChatLineModel::WrapList &wplist) {
-  quint16 cnt;
-  in >> cnt;
-  wplist.resize(cnt);
-  for(quint16 i = 0; i < cnt; i++) {
-    in >> wplist[i].start >> wplist[i].width >> wplist[i].trailing;
-  }
-  return in;
+
+QDataStream &operator>>(QDataStream &in, ChatLineModel::WrapList &wplist)
+{
+    quint16 cnt;
+    in >> cnt;
+    wplist.resize(cnt);
+    for (quint16 i = 0; i < cnt; i++) {
+        in >> wplist[i].start >> wplist[i].width >> wplist[i].trailing;
+    }
+    return in;
 }