1 // Copyright (C) 2017-20xx CEA/DEN, EDF R&D
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 // See http://www.salome-platform.org/ or
18 // email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
21 #ifndef BuildPlugin_Solid_H_
22 #define BuildPlugin_Solid_H_
24 #include "BuildPlugin.h"
26 #include <GeomAPI_Shape.h>
27 #include <ModelAPI_Feature.h>
29 class GeomAlgoAPI_MakeShape;
31 /// \class BuildPlugin_Solid
33 /// \brief Feature for creation of solid from faces or shells.
34 class BuildPlugin_Solid: public ModelAPI_Feature
37 /// Use plugin manager for features creation
41 inline static const std::string& ID()
43 static const std::string MY_ID("Solid");
47 /// Attribute name of base objects.
48 inline static const std::string& BASE_OBJECTS_ID()
50 static const std::string MY_BASE_OBJECTS_ID("base_objects");
51 return MY_BASE_OBJECTS_ID;
54 /// \return the kind of a feature.
55 BUILDPLUGIN_EXPORT virtual const std::string& getKind()
57 static std::string MY_KIND = BuildPlugin_Solid::ID();
61 /// Request for initialization of data model of the feature: adding all attributes.
62 BUILDPLUGIN_EXPORT virtual void initAttributes();
64 /// Creates a new part document if needed.
65 BUILDPLUGIN_EXPORT virtual void execute();
69 /// \param[out] theOriginalShapes list of original shapes
70 /// \param[out] theAlgorithm algorithm to build result
71 /// \return \c true if algorithm finished without errors
72 bool build(ListOfShape& theOriginalShapes, std::shared_ptr<GeomAlgoAPI_MakeShape>& theAlgorithm);
74 /// Store result of algorithm
75 void storeResult(const ListOfShape& theOriginalShapes,
76 const GeomShapePtr& theResultShape,
77 const std::shared_ptr<GeomAlgoAPI_MakeShape>& theAlgorithm);
79 /// Check the algorithm is failed
80 bool isAlgorithmFailed(const std::shared_ptr<GeomAlgoAPI_MakeShape>& theAlgorithm);
82 /// Explode compound to get single shape of specified type
83 /// \return Empty shape if there is more than one shape in compound
84 GeomShapePtr getSingleSubshape(const GeomShapePtr& theCompound,
85 const GeomAPI_Shape::ShapeType theShapeType);