Salome HOME
Debugging Symmetry feature.
[modules/shaper.git] / src / FeaturesPlugin / FeaturesPlugin_RevolutionBoolean.h
index b645190f7f8f193594a170075999174e48a65a21..2d6fab5af22a5b313461208cea1d7cf570c339bc 100644 (file)
@@ -7,82 +7,31 @@
 #ifndef FeaturesPlugin_RevolutionBoolean_H_
 #define FeaturesPlugin_RevolutionBoolean_H_
 
-#include <FeaturesPlugin_CompositeBoolean.h>
-
-/** \class FeaturesPlugin_RevolutionBoolean
- *  \ingroup Plugins
- *  \brief Interface for the composite revolution feature.
- */
-class FeaturesPlugin_RevolutionBoolean : public FeaturesPlugin_CompositeBoolean
+#include "FeaturesPlugin_Revolution.h"
+#include "FeaturesPlugin_CompositeBoolean.h"
+
+/// \class FeaturesPlugin_RevolutionBoolean
+/// \ingroup Plugins
+/// \brief Interface for the composite revolution feature.
+class FeaturesPlugin_RevolutionBoolean : public FeaturesPlugin_Revolution,
+                                         public FeaturesPlugin_CompositeBoolean
 {
 public:
-  /// Attribute name of an revolution axis.
-  inline static const std::string& AXIS_OBJECT_ID()
-  {
-    static const std::string MY_AXIS_ID("axis_object");
-    return MY_AXIS_ID;
-  }
-
-  /// attribute name for creation method
-  inline static const std::string& CREATION_METHOD()
-  {
-    static const std::string METHOD_ATTR("CreationMethod");
-    return METHOD_ATTR;
-  }
-
-  /// Attribute name of revolution to angle.
-  inline static const std::string& TO_ANGLE_ID()
-  {
-    static const std::string MY_TO_ANGLE_ID("to_angle");
-    return MY_TO_ANGLE_ID;
-  }
-
-  /// Attribute name of revolution from angle.
-  inline static const std::string& FROM_ANGLE_ID()
-  {
-    static const std::string MY_FROM_ANGLE_ID("from_angle");
-    return MY_FROM_ANGLE_ID;
-  }
-  
-  /// Attribute name of an object to which the revolution grows.
-  inline static const std::string& TO_OBJECT_ID()
-  {
-    static const std::string MY_TO_OBJECT_ID("to_object");
-    return MY_TO_OBJECT_ID;
-  }
-
-  /// Attribute name of extrusion offset.
-  inline static const std::string& TO_OFFSET_ID()
-  {
-    static const std::string MY_TO_OFFSET_ID("to_offset");
-    return MY_TO_OFFSET_ID;
-  }
-
-  /// Attribute name of an object from which the revolution grows.
-  inline static const std::string& FROM_OBJECT_ID()
-  {
-    static const std::string MY_FROM_OBJECT_ID("from_object");
-    return MY_FROM_OBJECT_ID;
-  }
-
-  /// Attribute name of extrusion offset.
-  inline static const std::string& FROM_OFFSET_ID()
-  {
-    static const std::string MY_FROM_OFFSET_ID("from_offset");
-    return MY_FROM_OFFSET_ID;
-  }
+  /// Request for initialization of data model of the feature: adding all attributes.
+  FEATURESPLUGIN_EXPORT virtual void initAttributes();
 
 protected:
-  /// Init attributes for revolution.
-  virtual void initMakeSolidsAttributes();
+  FeaturesPlugin_RevolutionBoolean(){};
 
-  /// Create solids from faces with revolution.
-  virtual void makeSolids(const ListOfShape& theFaces,
-                          ListOfShape& theResults,
-                          ListOfMakeShape& theAlgos);
+  // Creates revolutions.
+  bool makeGeneration(ListOfShape& theBaseShapes,
+                      ListOfMakeShape& theMakeShapes);
 
-protected:
-  FeaturesPlugin_RevolutionBoolean(){};
+  /// Stores generation history.
+  void storeGenerationHistory(ResultBodyPtr theResultBody,
+                              const GeomShapePtr theBaseShape,
+                              const std::shared_ptr<GeomAlgoAPI_MakeShape> theMakeShape,
+                              int& theTag);
 };
 
 #endif