X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_Validators.h;h=0e02a0e9fcbb1bfb861b010cf2ecaadde8e4c1f3;hb=857b1f72d9703c46c6c8c9bb239821d314344c86;hp=7d78aeb10a7f2e879ef26261605d81ae8dda8f1a;hpb=91540e31cc99e5f1eef3296b570b65abf580ca85;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_Validators.h b/src/PartSet/PartSet_Validators.h index 7d78aeb10..0e02a0e9f 100644 --- a/src/PartSet/PartSet_Validators.h +++ b/src/PartSet/PartSet_Validators.h @@ -21,7 +21,7 @@ //! A class to validate a selection for Distance constraint operation class PartSet_DistanceSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -29,7 +29,7 @@ class PartSet_DistanceSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Length constraint operation class PartSet_LengthSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -37,7 +37,7 @@ class PartSet_LengthSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Perpendicular constraint operation class PartSet_PerpendicularSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -45,7 +45,7 @@ class PartSet_PerpendicularSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Parallel constraint operation class PartSet_ParallelSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -53,7 +53,7 @@ class PartSet_ParallelSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Radius constraint operation class PartSet_RadiusSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -61,7 +61,7 @@ class PartSet_RadiusSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Rigid constraint operation class PartSet_RigidSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -70,7 +70,7 @@ class PartSet_RigidSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for coincedence constraint operation class PartSet_CoincidentSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -78,7 +78,7 @@ class PartSet_CoincidentSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Horizontal and Vertical constraints operation class PartSet_HVDirSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -86,7 +86,7 @@ class PartSet_HVDirSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Tangential constraints operation class PartSet_TangentSelection : public ModuleBase_SelectionValidator { - public: + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -94,7 +94,15 @@ class PartSet_TangentSelection : public ModuleBase_SelectionValidator //! A class to validate a selection for Fillet constraints operation class PartSet_FilletSelection : public ModuleBase_SelectionValidator { - public: + protected: + PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; +}; + +//! \ingroup Validators +//! A class to validate a selection for Angle constraints operation +class PartSet_AngleSelection : public ModuleBase_SelectionValidator +{ + protected: PARTSET_EXPORT virtual bool isValid(const ModuleBase_ISelection* theSelection) const; }; @@ -107,18 +115,28 @@ class PartSet_FilletSelection : public ModuleBase_SelectionValidator */ class PartSet_DifferentObjectsValidator : public ModelAPI_AttributeValidator { + //! Validator possible error types + enum ErrorType { + EqualObjects, + EqualAttributes, + EqualShapes, + EmptyShapes + }; public: //! Returns true if the attribute is good for the feature attribute //! \param theAttribute an attribute //! \param theArguments a list of arguments (names of attributes to check) virtual bool isValid(const AttributePtr& theAttribute, - const std::list& theArguments) const; + const std::list& theArguments, + std::string& theError) const; +private: + //! Returns error message for the error type + //! \param theType a type of error + //! \param thEqualObjectInfo an + std::string errorMessage(const PartSet_DifferentObjectsValidator::ErrorType& theType, + const std::string& thEqualObject, const std::string& theFirstAttribute, + const std::string& theSecondAttribute) const; -protected: - //! Checks whethe other feature attributes has a reference to the given attribute - //! \param theAttribute a source attribute to find object - //! \return a boolean value - bool featureHasReferences(const AttributePtr& theAttribute) const; }; /** @@ -132,23 +150,24 @@ class PartSet_SketchEntityValidator : public ModelAPI_AttributeValidator //! \param theAttribute an attribute //! \param theArguments a list of arguments (names of attributes to check) virtual bool isValid(const AttributePtr& theAttribute, - const std::list& theArguments) const; + const std::list& theArguments, + std::string& theError) const; }; -/**\class PartSet_SameTypeAttrValidator +/**\class PartSet_CoincidentAttr * \ingroup Validators - * \brief Validator for the tangent constraint input. - * - * It just checks that distance is greater than zero. + * \brief Validator to check whether there is a coincident constraint between + * the attribute and attribute of argument. */ -class PartSet_SameTypeAttrValidator : public ModelAPI_AttributeValidator +class PartSet_CoincidentAttr : public ModelAPI_AttributeValidator { public: //! returns true if attribute is valid //! \param theAttribute the checked attribute //! \param theArguments arguments of the attribute virtual bool isValid(const AttributePtr& theAttribute, - const std::list& theArguments) const; + const std::list& theArguments, + std::string& theError) const; };