1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
occt/tools/DFBrowserPane/DFBrowserPane_AttributePaneSelector.hxx
dpasukhi a5a7b3185b Coding - Apply .clang-format formatting #286
Update empty method guards to new style with regex (see PR).
Used clang-format 18.1.8.
New actions to validate code formatting is added.
Update .clang-format with disabling of include sorting.
  It is temporary changes, then include will be sorted.
Apply formatting for /src and /tools folder.
The files with .hxx,.cxx,.lxx,.h,.pxx,.hpp,*.cpp extensions.
2025-01-26 00:43:57 +00:00

73 lines
2.8 KiB
C++

// Created on: 2017-06-16
// Created by: Natalia ERMOLAEVA
// Copyright (c) 2017 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#ifndef DFBrowserPane_AttributePaneSelector_H
#define DFBrowserPane_AttributePaneSelector_H
#include <Standard.hxx>
#include <Standard_WarningsDisable.hxx>
#include <QObject>
#include <QItemSelection>
#include <Standard_WarningsRestore.hxx>
#include <list>
class QItemSelectionModel;
//! \class DFBrowserPane_AttributePaneSelector
//! \brief Container of active selection models. It connects to selection changed signal of the
//! models and emits one signal for any selection.
class DFBrowserPane_AttributePaneSelector : public QObject
{
Q_OBJECT
public:
//! Constructor
Standard_EXPORT DFBrowserPane_AttributePaneSelector(QObject* theParent);
//! Destructor
Standard_EXPORT virtual ~DFBrowserPane_AttributePaneSelector();
//! Fills the pane selection by the given models. Disconnect it from the previous model and
//! connect to new models \param theModels a list of selection models
Standard_EXPORT void SetCurrentSelectionModels(const std::list<QItemSelectionModel*>& theModels);
//! Clears selection in all selection models using block for selection changed flag
Standard_EXPORT void ClearSelected();
signals:
//! Signal about selection changed in the model
//! \param theSelected selected items
//! \param theDeselected deselected items
//! \param theModel a selection model where the selection happens
void tableSelectionChanged(const QItemSelection& theSelected,
const QItemSelection& theDeselected,
QItemSelectionModel* theModel);
protected slots:
//! Listens selectionChanged() of the model and emits signal tableSelectionChanged filled with the
//! selection model \param theSelected selected items \param theDeselected deselected items
void onTableSelectionChanged(const QItemSelection& theSelected,
const QItemSelection& theDeselected);
private:
std::list<QItemSelectionModel*> mySelectionModels; //!< container of selection models
bool mySendSelectionChangeBlocked; //!< flag is selection processing should not performed, avoid
//!< cyclic dependency
};
#endif