X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMESHFiltersSelection%2FSMESH_LogicalFilter.cxx;h=dce630ad31b93556a65a1de4cd7a6c98cf34f1cf;hp=5033f8e1390e6c8fb9760d026643e1eb6dc501c8;hb=20d9e162bd67182cbfa841bbfc9319919f4703e3;hpb=2754c581d371f9bf52b3c538a7bde55f10f6523c diff --git a/src/SMESHFiltersSelection/SMESH_LogicalFilter.cxx b/src/SMESHFiltersSelection/SMESH_LogicalFilter.cxx index 5033f8e13..dce630ad3 100644 --- a/src/SMESHFiltersSelection/SMESH_LogicalFilter.cxx +++ b/src/SMESHFiltersSelection/SMESH_LogicalFilter.cxx @@ -1,35 +1,40 @@ -// Copyright (C) 2005 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, +// Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE +// +// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS -// +// // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 2.1 of the License. -// -// This library is distributed in the hope that it will be useful -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // + // File : SMESH_LogicalFilter.cxx // Module : SMESH - +// #include "SMESH_LogicalFilter.hxx" //======================================================================= // name : SMESH_LogicalFilter::SMESH_LogicalFilter // Purpose : Constructor //======================================================================= -SMESH_LogicalFilter::SMESH_LogicalFilter (const QPtrList& theFilters, - const int theLogOp) +SMESH_LogicalFilter::SMESH_LogicalFilter (const QList& theFilters, + const int theLogOp, + bool takeOwnership) + : myOwnership( takeOwnership ) { - setFilters(theFilters); + setFilters(theFilters); setOperation(theLogOp); } @@ -39,6 +44,7 @@ SMESH_LogicalFilter::SMESH_LogicalFilter (const QPtrList& //======================================================================= SMESH_LogicalFilter::~SMESH_LogicalFilter() { + deleteFilters(); } //======================================================================= @@ -47,10 +53,8 @@ SMESH_LogicalFilter::~SMESH_LogicalFilter() //======================================================================= bool SMESH_LogicalFilter::isOk (const SUIT_DataOwner* owner) const { - bool res = true; - QPtrListIterator it (myFilters); SUIT_SelectionFilter* filter; - for (; ((filter = it.current()) != 0) && res; ++it) + foreach( filter, myFilters ) { if (myOperation == LO_OR && filter->isOk(owner)) return true; @@ -67,8 +71,9 @@ bool SMESH_LogicalFilter::isOk (const SUIT_DataOwner* owner) const // name : SMESH_LogicalFilter::setFilters // Purpose : Set new list of filters. Old wilters are removed //======================================================================= -void SMESH_LogicalFilter::setFilters (const QPtrList& theFilters) +void SMESH_LogicalFilter::setFilters (const QList& theFilters) { + deleteFilters(); myFilters = theFilters; } @@ -85,7 +90,7 @@ void SMESH_LogicalFilter::setOperation (const int theLogOp) // name : SMESH_LogicalFilter::getFilters // Purpose : Get list of filters //======================================================================= -const QPtrList SMESH_LogicalFilter::getFilters() const +const QList SMESH_LogicalFilter::getFilters() const { return myFilters; } @@ -98,3 +103,18 @@ int SMESH_LogicalFilter::getOperation() const { return myOperation; } +//================================================================================ +/*! + * \brief Deletes filters if has an ownership + */ +//================================================================================ + +void SMESH_LogicalFilter::deleteFilters() +{ + if ( myOwnership ) + { + SUIT_SelectionFilter* filter; + foreach( filter, myFilters ) + delete filter; + } +}