Salome HOME
Issue #1366: Remove Sub-Shapes feature added.
[modules/shaper.git] / src / GeomValidators / GeomValidators_ShapeType.h
1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
2
3 // File:        GeomValidators_ShapeType.h
4 // Created:     19 Mar 2015
5 // Author:      Natalia ERMOLAEVA
6
7 #ifndef GeomValidators_ShapeType_H
8 #define GeomValidators_ShapeType_H
9
10 #include "GeomValidators.h"
11 #include "ModelAPI_AttributeValidator.h"
12
13 #include <GeomAPI_Shape.h>
14
15 #include <string>
16
17 /**
18 * \ingroup Validators
19 * A validator for shape types, such as vertex, line, circe or arc.
20 * If there are some argument parameters, this validator returns true if the attribute satisfied
21 * at least one argument (OR combination of arguments).
22 */
23 class GeomValidators_ShapeType : public ModelAPI_AttributeValidator
24 {
25  public:
26   /// Type of shape
27   enum TypeOfShape
28   {
29     Empty,
30     Vertex,
31     Edge,
32     Line,
33     Circle,
34     Wire,
35     Face,
36     Plane,
37     Shell,
38     Solid,
39     CompSolid,
40     Compound,
41     AnyShape
42   };
43
44  public:
45    GEOMVALIDATORS_EXPORT GeomValidators_ShapeType() {}
46   //! Returns true if attribute has shape type listed in the parameter arguments
47   //! \param[in] theAttribute the checked attribute
48   //! \param[in] theArguments arguments of the attribute
49   //! \param[out] theError error message.
50   GEOMVALIDATORS_EXPORT virtual bool isValid(const AttributePtr& theAttribute,
51                                              const std::list<std::string>& theArguments,
52                                              std::string& theError) const;
53 protected:
54   /// Convert string to TypeOfShape value
55   /// \param theType a string value
56   static TypeOfShape shapeType(const std::string& theType);
57
58   /// Returns true if the attibute's object type satisfies the argument value
59   /// \param[in] theAttribute a checked attribute
60   /// \param[in] theShapeType a type of shape
61   /// \param[out] theError error message.
62   bool isValidAttribute(const AttributePtr& theAttribute,
63                         const TypeOfShape theShapeType,
64                         std::string& theError) const;
65
66   /// Returns true if the attibute's object type satisfies the argument value
67   /// \param[in] theObject a checked object
68   /// \param[in] theShapeType a shape type
69   /// \param[out] theError error message.
70   bool isValidObject(const ObjectPtr& theObject,
71                      const TypeOfShape theShapeType,
72                      std::string& theError) const;
73
74   /// Returns true if the attibute's object type satisfies the argument value
75   /// \param[in] theShape a checked shape
76   /// \param[in] theShapeType a shape type
77   /// \param[out] theError error message.
78   bool isValidShape(const GeomShapePtr theShape,
79                     const TypeOfShape theShapeType,
80                     std::string& theError) const;
81
82 };
83
84 #endif