X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FFeaturesPlugin%2FFeaturesPlugin_Symmetry.cpp;h=38b50f39391e0d19cd01cf266d4ef525c52f57e2;hb=e60b61962b051180dab78bb91977d58d59ca7614;hp=f2a56036fb1da37968a2de87b3e2895a18706d7a;hpb=bc250222327d0b3f7e67fb35f0a1967c746e1fc6;p=modules%2Fshaper.git diff --git a/src/FeaturesPlugin/FeaturesPlugin_Symmetry.cpp b/src/FeaturesPlugin/FeaturesPlugin_Symmetry.cpp index f2a56036f..38b50f393 100644 --- a/src/FeaturesPlugin/FeaturesPlugin_Symmetry.cpp +++ b/src/FeaturesPlugin/FeaturesPlugin_Symmetry.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// Copyright (C) 2014-2019 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 @@ -12,10 +12,9 @@ // // 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 +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or -// email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #include @@ -25,6 +24,7 @@ #include #include #include +#include #include #include @@ -134,6 +134,7 @@ void FeaturesPlugin_Symmetry::performSymmetryByPoint() } // Moving each object. + std::string anError; int aResultIndex = 0; std::list::iterator aContext = aContextes.begin(); for(ListOfShape::iterator anObjectsIt = anObjects.begin(); anObjectsIt != anObjects.end(); @@ -160,19 +161,8 @@ void FeaturesPlugin_Symmetry::performSymmetryByPoint() aSymmetryAlgo->build(); // Checking that the algorithm worked properly. - if(!aSymmetryAlgo->isDone()) { - static const std::string aFeatureError = "Error: Symmetry algorithm failed."; - setError(aFeatureError); - break; - } - if(aSymmetryAlgo->shape()->isNull()) { - static const std::string aShapeError = "Error: Resulting shape is Null."; - setError(aShapeError); - break; - } - if(!aSymmetryAlgo->isValid()) { - std::string aFeatureError = "Error: Resulting shape is not valid."; - setError(aFeatureError); + if (GeomAlgoAPI_Tools::AlgoError::isAlgorithmFailed(aSymmetryAlgo, getKind(), anError)) { + setError(anError); break; } @@ -218,11 +208,6 @@ void FeaturesPlugin_Symmetry::performSymmetryByAxis() GeomAPI_ShapeIterator anIt(aShape); anEdge = anIt.current()->edge(); } - else - { - setError(aSelectionError); - return; - } if (!anEdge.get()) { @@ -235,6 +220,7 @@ void FeaturesPlugin_Symmetry::performSymmetryByAxis() // Moving each object. + std::string anError; int aResultIndex = 0; std::list::iterator aContext = aContextes.begin(); for(ListOfShape::iterator anObjectsIt = anObjects.begin(); anObjectsIt != anObjects.end(); @@ -261,19 +247,8 @@ void FeaturesPlugin_Symmetry::performSymmetryByAxis() aSymmetryAlgo->build(); // Checking that the algorithm worked properly. - if(!aSymmetryAlgo->isDone()) { - static const std::string aFeatureError = "Error: Symmetry algorithm failed."; - setError(aFeatureError); - break; - } - if(aSymmetryAlgo->shape()->isNull()) { - static const std::string aShapeError = "Error: Resulting shape is Null."; - setError(aShapeError); - break; - } - if(!aSymmetryAlgo->isValid()) { - std::string aFeatureError = "Error: Resulting shape is not valid."; - setError(aFeatureError); + if (GeomAlgoAPI_Tools::AlgoError::isAlgorithmFailed(aSymmetryAlgo, getKind(), anError)) { + setError(anError); break; } @@ -319,11 +294,6 @@ void FeaturesPlugin_Symmetry::performSymmetryByPlane() GeomAPI_ShapeIterator anIt(aShape); aFace = anIt.current()->face(); } - else - { - setError(aSelectionError); - return; - } if (!aFace.get()) { @@ -336,6 +306,7 @@ void FeaturesPlugin_Symmetry::performSymmetryByPlane() // Moving each object. + std::string anError; int aResultIndex = 0; std::list::iterator aContext = aContextes.begin(); for(ListOfShape::iterator anObjectsIt = anObjects.begin(); anObjectsIt != anObjects.end(); @@ -361,19 +332,8 @@ void FeaturesPlugin_Symmetry::performSymmetryByPlane() aSymmetryAlgo->build(); // Checking that the algorithm worked properly. - if(!aSymmetryAlgo->isDone()) { - static const std::string aFeatureError = "Error: Symmetry algorithm failed."; - setError(aFeatureError); - break; - } - if(aSymmetryAlgo->shape()->isNull()) { - static const std::string aShapeError = "Error: Resulting shape is Null."; - setError(aShapeError); - break; - } - if(!aSymmetryAlgo->isValid()) { - std::string aFeatureError = "Error: Resulting shape is not valid."; - setError(aFeatureError); + if (GeomAlgoAPI_Tools::AlgoError::isAlgorithmFailed(aSymmetryAlgo, getKind(), anError)) { + setError(anError); break; } @@ -409,8 +369,12 @@ void FeaturesPlugin_Symmetry::buildResult( // Store and name the result. ResultBodyPtr aResultBody = document()->createBody(data(), theResultIndex); - aResultBody->storeModified(theBaseShape, aCompound); - FeaturesPlugin_Tools::loadModifiedShapes(aResultBody, theBaseShape, anAlgoList, "Symmetried"); + + ListOfShape aBaseShapes; + aBaseShapes.push_back(theBaseShape); + FeaturesPlugin_Tools::loadModifiedShapes(aResultBody, aBaseShapes, ListOfShape(), + anAlgoList, aCompound, "Symmetried"); + setResult(aResultBody, theResultIndex); }