-// Copyright (C) 2014-2019 CEA/DEN, EDF R&D
+// Copyright (C) 2014-2024 CEA, EDF
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
/// Attribute name for creation method.
inline static const std::string& CREATION_METHOD_BY_SIZES()
{
- static const std::string MY_CREATION_METHOD_ID("BySizes");
- return MY_CREATION_METHOD_ID;
+ static const std::string MY_CREATION_METHOD_BY_SIZES("BySizes");
+ return MY_CREATION_METHOD_BY_SIZES;
}
/// Attribute name for creation method.
inline static const std::string& CREATION_METHOD_BY_PLANES()
{
- static const std::string MY_CREATION_METHOD_ID("ByPlanesAndOffsets");
- return MY_CREATION_METHOD_ID;
+ static const std::string MY_CREATION_METHOD_BY_PLANES("ByPlanesAndOffsets");
+ return MY_CREATION_METHOD_BY_PLANES;
+ }
+
+ /// Attribute name for creation method.
+ inline static const std::string& CREATION_METHOD_THROUGH_ALL()
+ {
+ static const std::string MY_CREATION_METHOD_THROUGH_ALL("ThroughAll");
+ return MY_CREATION_METHOD_THROUGH_ALL;
}
/// Attribute name of an object to which the extrusion grows.
/// Request for initialization of data model of the feature: adding all attributes.
FEATURESPLUGIN_EXPORT virtual void initAttributes();
- /// Creates a new part document if needed.
+ /// Performs the algorithm and stores results it in the data structure.
FEATURESPLUGIN_EXPORT virtual void execute();
protected:
/// Generates extrusions.
/// \param[out] theBaseShapes list of base shapes.
+ /// \param[out] theBoundaryShapes list of faces limiting the extrusion
/// \param[out] theMakeShapes list of according algos.
/// \return false in case one of algo failed.
bool makeExtrusions(ListOfShape& theBaseShapes,
+ ListOfShape& theBoundaryShapes,
ListOfMakeShape& theMakeShapes);
+
+ /// Stores result of generation.
+ void storeResultWithBoundaries(const GeomShapePtr theBaseShape,
+ const ListOfShape& theBoundaryShapes,
+ const std::shared_ptr<GeomAlgoAPI_MakeShape> theMakeShape,
+ const int theIndex = 0);
+
+ /// Retrieve direction argument.
+ void getDirection(std::shared_ptr<GeomAPI_Dir>& theDir);
+
+ /// Retrieve or calculate prism sizes.
+ virtual void getSizes(double& theToSize, double& theFromSize);
};
#endif