+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
+
// File: ModelAPI_Validator.hxx
// Created: 2 Jul 2014
// Author: Mikhail PONIKAROV
#define ModelAPI_Validator_H_
#include <ModelAPI.h>
+#include <ModelAPI_Feature.h>
#include <memory>
#include <list>
class ModelAPI_Feature;
+class Events_InfoMessage;
/**\class ModelAPI_Validator
* \ingroup DataModel
/**\class ModelAPI_ValidatorsFactory
* \ingroup DataModel
- * \breif Manages the registered validators
+ * \brief Manages the registered validators
*
* Allows to get a validator by the feature identifier and
* the attribute identifier (if attribute is validated).
const std::string& theAttrID,
const std::list<std::string>& theArguments) = 0;
+ /// Validators is a list of pairs <Validator, list of arguments>
+ typedef std::list<std::pair<std::string, std::list<std::string> > > Validators;
/// Provides a validator for the feature, returns NULL if no validator
virtual void validators(const std::string& theFeatureID,
- std::list<ModelAPI_Validator*>& theResult,
- std::list<std::list<std::string> >& theArguments) const = 0;
+ Validators& theResult) 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<ModelAPI_Validator*>& theValidators,
- std::list<std::list<std::string> >& theArguments) const = 0;
+ Validators& theResult) const = 0;
/// Returns registered validator by its Id
virtual const ModelAPI_Validator* validator(const std::string& theID) const = 0;
/// Returns true if feature and all its attributes are valid.
virtual bool validate(const std::shared_ptr<ModelAPI_Feature>& theFeature) const = 0;
+ /// Returns true if the attribute is valid.
+ virtual bool validate(const std::shared_ptr<ModelAPI_Attribute>& theAttribute,
+ std::string& theValidator, Events_InfoMessage& theError) const = 0;
+
/// register that this attribute in feature is not obligatory for the feature execution
/// so, it is not needed for the standard validation mechanism
virtual void registerNotObligatory(std::string theFeature, std::string theAttribute) = 0;
+ /// Returns true if the attribute in feature is not obligatory for the feature execution
+ virtual bool isNotObligatory(std::string theFeature, std::string theAttribute) = 0;
+
/// register that this attribute conceals in the object browser
/// all referenced features after execution
virtual void registerConcealment(std::string theFeature, std::string theAttribute) = 0;
/// Returns true that it was registered that attribute conceals the referenced result
virtual bool isConcealed(std::string theFeature, std::string theAttribute) = 0;
+ /// Registers (by Recover feature) cancel of concealment of specific result by specific feature.
+ /// If theCanceledFeat is empty, the concealment is canceled for this result forever.
+ virtual void registerUnconcealment(std::shared_ptr<ModelAPI_Result> theUnconcealed,
+ std::shared_ptr<ModelAPI_Feature> theCanceledFeat) = 0;
+
+ /// Disables cancel of concealment of specific result by specific feature.
+ virtual void disableUnconcealment(std::shared_ptr<ModelAPI_Result> theUnconcealed,
+ std::shared_ptr<ModelAPI_Feature> theCanceledFeat) = 0;
+
+ /// Returns true if concealment is canceled.
+ virtual bool isUnconcealed(std::shared_ptr<ModelAPI_Result> theUnconcealed,
+ std::shared_ptr<ModelAPI_Feature> theCanceledFeat) = 0;
+
+ /// Register the case-attribute: this attribute is checked only if its case is selected
+ virtual void registerCase(std::string theFeature, std::string theAttribute,
+ const std::list<std::pair<std::string, std::string> >& theCases) = 0;
+
+ /// Returns true if the attribute must be checked (the case is selected)
+ virtual bool isCase(FeaturePtr theFeature, std::string theAttribute) = 0;
+
protected:
/// Get instance from Session
ModelAPI_ValidatorsFactory()