X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fselectionmodelsynchronizer.h;h=33550854ed2ace1b9e5e7f3aef479795cb0662ed;hp=2e153b657e71e7904599e2b3a63fe25cdbb0bad5;hb=46d75f41de7c1aaee605c096da28d4b0d8abf138;hpb=e190d576540cf5dfb2e63d33a69662083f3db210 diff --git a/src/client/selectionmodelsynchronizer.h b/src/client/selectionmodelsynchronizer.h index 2e153b65..33550854 100644 --- a/src/client/selectionmodelsynchronizer.h +++ b/src/client/selectionmodelsynchronizer.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -32,7 +32,7 @@ class SelectionModelSynchronizer : public QObject { public: SelectionModelSynchronizer(QAbstractItemModel *parent = 0); - void addSelectionModel(QItemSelectionModel *selectionModel); + void synchronizeSelectionModel(QItemSelectionModel *selectionModel); void removeSelectionModel(QItemSelectionModel *selectionModel); inline QAbstractItemModel *model() { return _model; } @@ -40,13 +40,9 @@ public: inline QModelIndex currentIndex() const { return _selectionModel.currentIndex(); } inline QItemSelection currentSelection() const { return _selectionModel.selection(); } -signals: - void setCurrentIndex(const QModelIndex ¤t, QItemSelectionModel::SelectionFlags command); - void select(const QItemSelection &selected, QItemSelectionModel::SelectionFlags command); - private slots: - void mappedCurrentChanged(const QModelIndex ¤t, const QModelIndex &previous); - void mappedSelectionChanged(const QItemSelection &selected, const QItemSelection &previous); + void syncedCurrentChanged(const QModelIndex ¤t, const QModelIndex &previous); + void syncedSelectionChanged(const QItemSelection &selected, const QItemSelection &previous); void setCurrentIndex(const QModelIndex &index); void setCurrentSelection(const QItemSelection &selection); @@ -54,15 +50,21 @@ private slots: void currentChanged(const QModelIndex ¤t, const QModelIndex &previous); void selectionChanged(const QItemSelection &selected, const QItemSelection &deselected); + void selectionModelDestroyed(QObject *object); + private: QAbstractItemModel *_model; QItemSelectionModel _selectionModel; + bool _changeCurrentEnabled; + bool _changeSelectionEnabled; bool checkBaseModel(QItemSelectionModel *model); + QModelIndex mapFromSource(const QModelIndex &sourceIndex, const QItemSelectionModel *selectionModel); + QItemSelection mapSelectionFromSource(const QItemSelection &sourceSelection, const QItemSelectionModel *selectionModel); QModelIndex mapToSource(const QModelIndex &index, QItemSelectionModel *selectionModel); QItemSelection mapSelectionToSource(const QItemSelection &selection, QItemSelectionModel *selectionModel); - + QSet _selectionModels; }; #endif