Salome HOME
782d9eaeb3b4f61888d85fb37b3ed0b99be39478
[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   //  the edge type
27   enum TypeOfShape
28   {
29     Empty,
30     Vertex,
31     Edge,
32     Line,
33     Circle,
34     Face,
35     Solid,
36     Compound,
37     AnyShape
38   };
39
40  public:
41    GEOMVALIDATORS_EXPORT GeomValidators_ShapeType() {}
42   //! returns true if attribute is valid
43   //! \param theAttribute the checked attribute
44   //! \param theArguments arguments of the attribute
45   GEOMVALIDATORS_EXPORT virtual bool isValid(const AttributePtr& theAttribute,
46                                              const std::list<std::string>& theArguments) const;
47 protected:
48   /// Convert string to TypeOfShape value
49   /// \param theType a string value
50   static TypeOfShape shapeType(const std::string& theType);
51
52   bool isValidArgument(const AttributePtr& theAttribute,
53                        const std::string& theArgument) const;
54
55   /// Returns true if the attibute's object type satisfies the argument value
56   /// \param theAttribute a checked attribute
57   /// \param theArgument a parameter
58   bool isValidAttribute(const AttributePtr& theAttribute,
59                         const TypeOfShape theShapeType) const;
60
61   /// Returns true if the attibute's object type satisfies the argument value
62   /// \param theAttribute a checked object
63   /// \param theShapeType a shape type
64   bool isValidObject(const ObjectPtr& theObject,
65                      const TypeOfShape theShapeType) const;
66
67   /// Returns true if the attibute's object type satisfies the argument value
68   /// \param theShape a checked shape
69   /// \param theShapeType a shape type
70   bool isValidShape(const GeomShapePtr theShape,
71                     const TypeOfShape theShapeType) const;
72
73 };
74
75 #endif