-// Copyright (C) 2017-20xx CEA/DEN, EDF R&D
+// Copyright (C) 2017-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
//
// 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<mailto:webmaster.salome@opencascade.com>
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
//
#include "BuildPlugin_Filling.h"
#include <GeomAlgoAPI_Copy.h>
#include <GeomAlgoAPI_Filling.h>
#include <GeomAlgoAPI_ShapeTools.h>
+#include <GeomAlgoAPI_Tools.h>
#include <GeomAPI_Pnt.h>
#include <GeomAPI_ShapeExplorer.h>
data()->addAttribute(TOLERANCE_3D_ID(), ModelAPI_AttributeDouble::typeId());
data()->addAttribute(APPROXIMATION_ID(), ModelAPI_AttributeBoolean::typeId());
- restoreDefaultParameters();
- string(ADVANCED_OPTIONS_ID())->setValue("");
+ if (string(ADVANCED_OPTIONS_ID())->value().empty())
+ restoreDefaultParameters();
}
//=================================================================================================
// get base objects list
AttributeSelectionListPtr aSelectionList = selectionList(BASE_OBJECTS_ID());
- if (aSelectionList->size() <= 1)
+ if (aSelectionList->size() <= 1) {
+ setError("Not enough objects is selected");
return;
+ }
// collect base shapes
for(int anIndex = 0; anIndex < aSelectionList->size(); ++anIndex) {
// build result
aFilling->build(aParameters.isApprox);
- if (isAlgorithmFailed(aFilling)) {
+ std::string anError;
+ if (GeomAlgoAPI_Tools::AlgoError::isAlgorithmFailed(aFilling, getKind(), anError)) {
+ setError(anError);
removeResults(0);
return;
}
setResult(aResultBody, 0);
}
-bool BuildPlugin_Filling::isAlgorithmFailed(
- const std::shared_ptr<GeomAlgoAPI_MakeShape>& theAlgorithm)
-{
- if (!theAlgorithm->isDone()) {
- static const std::string aFeatureError = "Error: filling algorithm failed.";
- std::string anAlgoError = theAlgorithm->getError();
- if (anAlgoError.empty())
- anAlgoError = aFeatureError;
- else
- anAlgoError = aFeatureError + " " + anAlgoError;
- setError(anAlgoError);
- return true;
- }
- if (theAlgorithm->shape()->isNull()) {
- static const std::string aShapeError = "Error: Resulting shape of filling is Null.";
- setError(aShapeError);
- return true;
- }
- if (!theAlgorithm->isValid()) {
- std::string aFeatureError = "Error: Resulting shape of filling is not valid.";
- setError(aFeatureError);
- return true;
- }
- return false;
-}
-
//=================================================================================================
void BuildPlugin_Filling::attributeChanged(const std::string& theID)
{