X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Ftreemodel.h;h=5ff823ac41bcb3d88ddd8acdd3b6ece0a1e46774;hp=da1f5fd823291d0f660616c7def3d29962931a9b;hb=9d4fbba1e7390f7cbc60aed962bf9d36ac111263;hpb=e733408e4759473bf38831f498f48a0f2f5e6dc7 diff --git a/src/client/treemodel.h b/src/client/treemodel.h index da1f5fd8..5ff823ac 100644 --- a/src/client/treemodel.h +++ b/src/client/treemodel.h @@ -27,6 +27,8 @@ #include #include +#include // needed for debug + /***************************************** * general item used in the Tree Model *****************************************/ @@ -38,11 +40,16 @@ public: AbstractTreeItem(AbstractTreeItem *parent = 0); virtual ~AbstractTreeItem(); - void appendChild(int column, AbstractTreeItem *child); - void appendChild(AbstractTreeItem *child); + bool newChild(int column, AbstractTreeItem *child); + bool newChild(AbstractTreeItem *child); + + bool removeChild(int column, int row); + bool removeChild(int row); + + bool removeChildById(int column, const quint64 &id); + bool removeChildById(const quint64 &id); - void removeChild(int column, int row); - void removeChild(int row); + void removeAllChilds(); virtual quint64 id() const; @@ -58,6 +65,7 @@ public: virtual int columnCount() const = 0; virtual QVariant data(int column, int role) const = 0; + virtual bool setData(int column, const QVariant &value, int role) = 0; virtual Qt::ItemFlags flags() const; virtual void setFlags(Qt::ItemFlags); @@ -68,16 +76,15 @@ public: signals: void dataChanged(int column = -1); - void newChild(AbstractTreeItem *); - void childDestroyed(int row); - -private slots: - void childDestroyed(); + void beginAppendChilds(int column, int firstRow, int lastRow); + void endAppendChilds(); + + void beginRemoveChilds(int column, int firstRow, int lastRow); + void endRemoveChilds(); + private: QHash > _childItems; - QHash > _childHash; // uint to be compatible to qHash functions FIXME test this - AbstractTreeItem *_parentItem; Qt::ItemFlags _flags; int defaultColumn() const; @@ -93,7 +100,10 @@ class SimpleTreeItem : public AbstractTreeItem { public: SimpleTreeItem(const QList &data, AbstractTreeItem *parent = 0); virtual ~SimpleTreeItem(); + virtual QVariant data(int column, int role) const; + virtual bool setData(int column, const QVariant &value, int role); + virtual int columnCount() const; private: @@ -113,6 +123,8 @@ public: virtual ~PropertyMapItem(); virtual QVariant data(int column, int role) const; + virtual bool setData(int column, const QVariant &value, int role); + virtual int columnCount() const; void appendProperty(const QString &property); @@ -132,13 +144,15 @@ public: TreeModel(const QList &, QObject *parent = 0); virtual ~TreeModel(); - QVariant data(const QModelIndex &index, int role) const; + virtual QVariant data(const QModelIndex &index, int role) const; + virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole); + virtual Qt::ItemFlags flags(const QModelIndex &index) const; QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const; QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const; QModelIndex indexById(quint64 id, const QModelIndex &parent = QModelIndex()) const; - QModelIndex indexByItem(AbstractTreeItem *item) const; + QModelIndex indexByItem(AbstractTreeItem *item, int column = 0) const; QModelIndex parent(const QModelIndex &index) const; @@ -149,16 +163,30 @@ public: private slots: void itemDataChanged(int column = -1); - void newChild(AbstractTreeItem *child); - void childDestroyed(int row); - + + void beginAppendChilds(int column, int firstRow, int lastRow); + void endAppendChilds(); + + void beginRemoveChilds(int column, int firstRow, int lastRow); + void endRemoveChilds(); + protected: - void appendChild(AbstractTreeItem *parent, AbstractTreeItem *child); + AbstractTreeItem *rootItem; - bool removeRow(int row, const QModelIndex &parent = QModelIndex()); - bool removeRows(int row, int count, const QModelIndex &parent = QModelIndex()); +private: + void connectItem(AbstractTreeItem *item); - AbstractTreeItem *rootItem; + struct ChildStatus { + QModelIndex parent; + int childCount; + int start; + int end; + inline ChildStatus(QModelIndex parent_, int cc_, int s_, int e_) : parent(parent_), childCount(cc_), start(s_), end(e_) {}; + }; + ChildStatus _childStatus; + int _aboutToRemoveOrInsert; + // QLinkedList _childStatus; + }; #endif