X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fbuffermodel.h;h=0be559aaf287989e4ea0dd49a6b65c28eedf7a31;hp=e45c60e656ce10a2b8322f948f5b25432c93243f;hb=1b2d3ea62867220d7bffc3b23dda1dc14d429007;hpb=50706d89d4d60e258ebb6873d3778383621898e4 diff --git a/src/client/buffermodel.h b/src/client/buffermodel.h index e45c60e6..0be559aa 100644 --- a/src/client/buffermodel.h +++ b/src/client/buffermodel.h @@ -23,16 +23,13 @@ #include #include -#include #include "types.h" +#include "selectionmodelsynchronizer.h" class NetworkModel; -#include "selectionmodelsynchronizer.h" -#include "modelpropertymapper.h" class MappedSelectionModel; class QAbstractItemView; -class Buffer; class BufferModel : public QSortFilterProxyModel { Q_OBJECT @@ -43,24 +40,18 @@ public: bool filterAcceptsRow(int sourceRow, const QModelIndex &parent) const; - inline SelectionModelSynchronizer *selectionModelSynchronizer() { return _selectionModelSynchronizer; } - inline ModelPropertyMapper *propertyMapper() { return _propertyMapper; } - + inline const SelectionModelSynchronizer *selectionModelSynchronizer() const { return &_selectionModelSynchronizer; } + inline QItemSelectionModel *standardSelectionModel() const { return const_cast(&_standardSelectionModel); } + void synchronizeSelectionModel(MappedSelectionModel *selectionModel); void synchronizeView(QAbstractItemView *view); - void mapProperty(int column, int role, QObject *target, const QByteArray &property); -public slots: QModelIndex currentIndex(); - void setCurrentIndex(const QModelIndex &index, QItemSelectionModel::SelectionFlags command); - -signals: - void selectionChanged(const QModelIndex &); + void setCurrentIndex(const QModelIndex &newCurrent); private: - QPointer _selectionModelSynchronizer; - QPointer _propertyMapper; - BufferId currentBuffer; + SelectionModelSynchronizer _selectionModelSynchronizer; + QItemSelectionModel _standardSelectionModel; }; #endif // BUFFERMODEL_H