X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Validator.h;h=9c83a9d7e3f4c63e9dda372255a40dc0a70eaab2;hb=b501b9b003ec4f01c5369b4c281280269b596889;hp=6f9e26f2a765fbf4e8b221bfe30a510ba9a9934a;hpb=33563016b3ba881a507cfd4b782e6a4f96296df5;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Validator.h b/src/ModelAPI/ModelAPI_Validator.h index 6f9e26f2a..9c83a9d7e 100644 --- a/src/ModelAPI/ModelAPI_Validator.h +++ b/src/ModelAPI/ModelAPI_Validator.h @@ -29,13 +29,6 @@ class MODELAPI_EXPORT ModelAPI_Validator virtual ~ModelAPI_Validator() { } - - /// Returns true if feature and/or attributes are valid - /// \param theFeature the validated feature - /// \param theAttr the validated attribute ID, empty string of feature is validated - /// \param theArguments list of string, feature attribute names: dependent attributes - //virtual bool validate(const boost::shared_ptr& theFeature, - // const std::string theAttr, std::list theArguments) const = 0; }; typedef boost::shared_ptr ValidatorPtr; @@ -47,7 +40,7 @@ typedef boost::shared_ptr ValidatorPtr; * Allows to get a validator by the feature identifier and * the attribute identifier (if attribute is validated). * All accessible validators mustbe registered by the ID string first. - * The instance of this factory can be get in the PluginManager. + * The instance of this factory can be get in the Session. * Keeps the validator objects alive and just returns one of it by request. * All the needed information is provided to the validator as an argument, * this allows to work with them independently from the feature specific object. @@ -61,6 +54,11 @@ class MODELAPI_EXPORT ModelAPI_ValidatorsFactory /// Assigns validator to the feature virtual void assignValidator(const std::string& theID, const std::string& theFeatureID) = 0; + /// Assigns validator to the feature with arguments of the validator + virtual void assignValidator(const std::string& theID, + const std::string& theFeatureID, + const std::list& theArguments) = 0; + /// Assigns validator to the attribute of the feature virtual void assignValidator(const std::string& theID, const std::string& theFeatureID, const std::string& theAttrID, @@ -68,7 +66,8 @@ class MODELAPI_EXPORT ModelAPI_ValidatorsFactory /// Provides a validator for the feature, returns NULL if no validator virtual void validators(const std::string& theFeatureID, - std::list& theResult) const = 0; + std::list& theResult, + std::list >& theArguments) const = 0; /// Provides a validator for the attribute, returns NULL if no validator virtual void validators(const std::string& theFeatureID, const std::string& theAttrID, std::list& theValidators, @@ -77,13 +76,11 @@ class MODELAPI_EXPORT ModelAPI_ValidatorsFactory /// Returns registered validator by its Id virtual const ModelAPI_Validator* validator(const std::string& theID) const = 0; - /// Returns the result of "validate" method for attribute of validator. - /// If validator is not exists, returns true: everything is valid by default. - //virtual bool validate( - // const boost::shared_ptr& theFeature, const std::string& theAttrID) const = 0; + /// Returns true if feature and all its attributes are valid. + virtual bool validate(const boost::shared_ptr& theFeature) const = 0; protected: - /// Get instance from PluginManager + /// Get instance from Session ModelAPI_ValidatorsFactory() { }