/usr/include/paraview/pqSelectionAdaptor.h is in paraview-dev 4.0.1-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | /*=========================================================================
Program: ParaView
Module: pqSelectionAdaptor.h
Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.
All rights reserved.
ParaView is a free software; you can redistribute it and/or modify it
under the terms of the ParaView license version 1.2.
See License_v1.2.txt for the full ParaView license.
A copy of this license can be obtained by contacting
Kitware Inc.
28 Corporate Drive
Clifton Park, NY 12065
USA
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
=========================================================================*/
#ifndef __pqSelectionAdaptor_h
#define __pqSelectionAdaptor_h
#include "pqComponentsModule.h"
#include <QObject>
#include <QItemSelectionModel> //need for qtSelectionFlags
class pqServerManagerModelItem;
class QAbstractItemModel;
class QModelIndex;
/// pqSelectionAdaptor is the abstract base class for an adaptor that connects a
/// QItemSelectionModel to pqActiveObjects making it possible to update the
/// pqActiveObjects source selection when the QItemSelectionModel changes and
/// vice-versa.
/// Subclass typically only need to implement mapToItem() and mapFromItem().
class PQCOMPONENTS_EXPORT pqSelectionAdaptor : public QObject
{
Q_OBJECT
public:
virtual ~pqSelectionAdaptor();
/// Returns a pointer to the QItemSelectionModel.
QItemSelectionModel* getQSelectionModel() const
{ return this->QSelectionModel; }
protected:
pqSelectionAdaptor(QItemSelectionModel* pipelineSelectionModel);
/// Maps a pqServerManagerModelItem to an index in the QAbstractItemModel.
virtual QModelIndex mapFromItem(pqServerManagerModelItem* item) const = 0;
/// Maps a QModelIndex to a pqServerManagerModelItem.
virtual pqServerManagerModelItem* mapToItem(const QModelIndex& index) const =0;
/// Returns the QAbstractItemModel used by the QSelectionModel.
/// If QSelectionModel uses a QAbstractProxyModel, this method skips
/// over all such proxy models and returns the first non-proxy model
/// encountered.
const QAbstractItemModel* getQModel() const;
protected slots:
/// called when the selection in the Qt-model changes.
virtual void selectionChanged();
/// called when the ServerManager level selection (or current) changes.
virtual void currentProxyChanged();
virtual void proxySelectionChanged();
/// subclasses can override this method to provide model specific selection
/// overrides such as QItemSelection::Rows or QItemSelection::Columns etc.
virtual QItemSelectionModel::SelectionFlag qtSelectionFlags() const
{ return QItemSelectionModel::NoUpdate; }
private:
/// Given a QModelIndex for the QAbstractItemModel under the QItemSelectionModel,
/// this returns the QModelIndex for the inner most non-proxy
/// QAbstractItemModel.
QModelIndex mapToSource(const QModelIndex& inIndex) const;
/// Given a QModelIndex for the innermost non-proxy QAbstractItemModel,
/// this returns the QModelIndex for the QAbstractItemModel under the
/// QItemSelectionModel.
QModelIndex mapFromSource(const QModelIndex& inIndex,
const QAbstractItemModel* model) const;
QItemSelectionModel* QSelectionModel;
bool IgnoreSignals;
};
#endif
|