X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FFeaturesAPI%2FFeaturesAPI_Symmetry.cpp;h=876360c8aadcf33faebd76b84c5f7a0bb61584f9;hb=fc72d43b677baa05ae7fd317346fd8b723b799ed;hp=36888ef3e37ce03be2bc23df5dbb3124f65c3f43;hpb=9552f8739e93d153cde510b2cbaeddbfe68d3ee3;p=modules%2Fshaper.git diff --git a/src/FeaturesAPI/FeaturesAPI_Symmetry.cpp b/src/FeaturesAPI/FeaturesAPI_Symmetry.cpp index 36888ef3e..876360c8a 100644 --- a/src/FeaturesAPI/FeaturesAPI_Symmetry.cpp +++ b/src/FeaturesAPI/FeaturesAPI_Symmetry.cpp @@ -1,8 +1,21 @@ -// Copyright (C) 2014-2016 CEA/DEN, EDF R&D --> - -// File: FeaturesAPI_Symmetry.cpp -// Created: 07 Dec 2016 -// Author: Clarisse Genrault (CEA) +// Copyright (C) 2014-2023 CEA/DEN, EDF R&D +// +// 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, 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 +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// #include "FeaturesAPI_Symmetry.h" @@ -18,12 +31,14 @@ FeaturesAPI_Symmetry::FeaturesAPI_Symmetry(const std::shared_ptr& theFeature, - const std::list& theMainObjects, - const ModelHighAPI_Selection& theObject) + const std::list& theMainObjects, + const ModelHighAPI_Selection& theObject, + bool theKeepOriginal) : ModelHighAPI_Interface(theFeature) { if(initialize()) { fillAttribute(theMainObjects, mainObjects()); + fillAttribute(theKeepOriginal, keepOriginal()); GeomAPI_Shape::ShapeType aType = getShapeType(theObject); if(aType == GeomAPI_Shape::VERTEX) { setPoint(theObject); @@ -103,14 +118,24 @@ void FeaturesAPI_Symmetry::dump(ModelHighAPI_Dumper& theDumper) const theDumper << ", " << anAttrPlane; } + theDumper << ", keepOriginal = " << keepOriginal(); + + if (!aBase->data()->version().empty()) + theDumper << ", keepSubResults = True"; + theDumper << ")" << std::endl; } //================================================================================================== SymmetryPtr addSymmetry(const std::shared_ptr& thePart, - const std::list& theMainObjects, - const ModelHighAPI_Selection& theObject) + const std::list& theMainObjects, + const ModelHighAPI_Selection& theObject, + const bool theKeepOriginal, + const bool theKeepSubResults) { std::shared_ptr aFeature = thePart->addFeature(FeaturesAPI_Symmetry::ID()); - return SymmetryPtr(new FeaturesAPI_Symmetry(aFeature, theMainObjects, theObject)); + if (!theKeepSubResults) + aFeature->data()->setVersion(""); + return SymmetryPtr(new FeaturesAPI_Symmetry( + aFeature, theMainObjects, theObject, theKeepOriginal)); }