properly handling disconnects - this might even fix an antique bug with duplicate...
[quassel.git] / src / qtui / chatlinemodel.cpp
index 3cf68b1..6b770a8 100644 (file)
 
 #include "chatlinemodelitem.h"
 
-ChatLineModel::ChatLineModel(QObject *parent) : MessageModel(parent) {
-
-
+ChatLineModel::ChatLineModel(QObject *parent)
+  : MessageModel(parent)
+{
+  qRegisterMetaType<WrapList>("ChatLineModel::WrapList");
+  qRegisterMetaTypeStreamOperators<WrapList>("ChatLineModel::WrapList");
 }
 
-ChatLineModel::~ChatLineModel() {
-
+MessageModelItem *ChatLineModel::createMessageModelItem(const Message &msg) {
+  return new ChatLineModelItem(msg);
 }
 
 
-MessageModelItem *ChatLineModel::createMessageModelItem(const Message &msg) {
-  return new ChatLineModelItem(msg);
+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;
 }