X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_Validator.cpp;h=9875f74274a9af41843c9140761b3273f224734d;hb=f367061802012d6909c2619ef6b6c4cba86fc503;hp=ee5ab1a9ccad2ed6178752e68faec45fa51bfbdb;hpb=2ca8be5b9d184c33cbfd78b1259638f340eeb017;p=modules%2Fshaper.git diff --git a/src/Model/Model_Validator.cpp b/src/Model/Model_Validator.cpp index ee5ab1a9c..9875f7427 100644 --- a/src/Model/Model_Validator.cpp +++ b/src/Model/Model_Validator.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Model_Validator.cpp // Created: 2 Jul 2014 // Author: Mikhail PONIKAROV @@ -8,10 +10,9 @@ #include #include #include +#include #include -const static std::string kDefaultId = "Model_FeatureValidator"; - void Model_ValidatorsFactory::registerValidator(const std::string& theID, ModelAPI_Validator* theValidator) { @@ -90,7 +91,7 @@ void Model_ValidatorsFactory::validators(const std::string& theFeatureID, } } } - addDefaultValidators(theResult); + addDefaultValidators(theResult, theArguments); } void Model_ValidatorsFactory::validators(const std::string& theFeatureID, @@ -121,6 +122,7 @@ void Model_ValidatorsFactory::validators(const std::string& theFeatureID, Model_ValidatorsFactory::Model_ValidatorsFactory() : ModelAPI_ValidatorsFactory() { + const static std::string kDefaultId = "Model_FeatureValidator"; registerValidator(kDefaultId, new Model_FeatureValidator); } @@ -133,16 +135,20 @@ const ModelAPI_Validator* Model_ValidatorsFactory::validator(const std::string& return NULL; } -void Model_ValidatorsFactory::addDefaultValidators(std::list& theValidators) const +void Model_ValidatorsFactory::addDefaultValidators(std::list& theValidators, + std::list >& theArguments) const { + const static std::string kDefaultId = "Model_FeatureValidator"; std::map::const_iterator it = myIDs.find(kDefaultId); if(it == myIDs.end()) return; theValidators.push_back(it->second); + theArguments.push_back(std::list()); } -bool Model_ValidatorsFactory::validate(const boost::shared_ptr& theFeature) const +bool Model_ValidatorsFactory::validate(const std::shared_ptr& theFeature) const { + const static std::string kDefaultId = "Model_FeatureValidator"; // check feature validators first std::map::const_iterator aFeature = myFeatures.find(theFeature->getKind()); @@ -174,10 +180,12 @@ bool Model_ValidatorsFactory::validate(const boost::shared_ptr return false; } } + // check all attributes for validity - boost::shared_ptr aData = theFeature->data(); - if (!aData->isValid()) - return false; + std::shared_ptr aData = theFeature->data(); + // Validity of data is checked by "Model_FeatureValidator" (kDefaultId) + // if (!aData || !aData->isValid()) + // return false; static const std::string kAllTypes = ""; std::map >::const_iterator aFeatureIter = myAttrs.find(theFeature->getKind()); @@ -186,7 +194,7 @@ bool Model_ValidatorsFactory::validate(const boost::shared_ptr std::list::iterator anAttrIter = aLtAttributes.begin(); for (; anAttrIter != aLtAttributes.end(); anAttrIter++) { std::map::const_iterator anAttr = - aFeatureIter->second.find(*anAttrIter); + aFeatureIter->second.find(*anAttrIter); if (anAttr != aFeatureIter->second.end()) { AttrValidators::const_iterator aValIter = anAttr->second.cbegin(); for (; aValIter != anAttr->second.cend(); aValIter++) { @@ -198,8 +206,8 @@ bool Model_ValidatorsFactory::validate(const boost::shared_ptr const ModelAPI_AttributeValidator* anAttrValidator = dynamic_cast(aFound->second); if (anAttrValidator) { - if (!anAttrValidator->isValid(theFeature->data()->attribute(*anAttrIter), - aValIter->second)) { + AttributePtr anAttribute = theFeature->data()->attribute(*anAttrIter); + if (!anAttrValidator->isValid(anAttribute, aValIter->second)) { return false; } } @@ -211,9 +219,9 @@ bool Model_ValidatorsFactory::validate(const boost::shared_ptr return true; } -void Model_ValidatorsFactory::registerNotObligatory( - std::string theFeature, std::string theAttribute) +void Model_ValidatorsFactory::registerNotObligatory(std::string theFeature, std::string theAttribute) { + const static std::string kDefaultId = "Model_FeatureValidator"; std::map::const_iterator it = myIDs.find(kDefaultId); if (it != myIDs.end()) { Model_FeatureValidator* aValidator = dynamic_cast(it->second); @@ -221,4 +229,66 @@ void Model_ValidatorsFactory::registerNotObligatory( aValidator->registerNotObligatory(theFeature, theAttribute); } } -} \ No newline at end of file +} + +bool Model_ValidatorsFactory::isNotObligatory(std::string theFeature, std::string theAttribute) +{ + const static std::string kDefaultId = "Model_FeatureValidator"; + std::map::const_iterator it = myIDs.find(kDefaultId); + if (it != myIDs.end()) { + Model_FeatureValidator* aValidator = dynamic_cast(it->second); + if (aValidator) { + return aValidator->isNotObligatory(theFeature, theAttribute); + } + } + return false; // default +} + +void Model_ValidatorsFactory::registerConcealment(std::string theFeature, std::string theAttribute) +{ + std::map >::iterator aFind = myConcealed.find(theFeature); + if (aFind == myConcealed.end()) { + std::set aNewSet; + aNewSet.insert(theAttribute); + myConcealed[theFeature] = aNewSet; + } else { + aFind->second.insert(theAttribute); + } +} + +bool Model_ValidatorsFactory::isConcealed(std::string theFeature, std::string theAttribute) +{ + std::map >::iterator aFind = myConcealed.find(theFeature); + return aFind != myConcealed.end() && aFind->second.find(theAttribute) != aFind->second.end(); +} + +void Model_ValidatorsFactory::registerCase(std::string theFeature, std::string theAttribute, + std::string theSwitchId, std::string theCaseId) +{ + std::map > >::iterator + aFindFeature = myCases.find(theFeature); + if (aFindFeature == myCases.end()) { + myCases[theFeature] = std::map >(); + aFindFeature = myCases.find(theFeature); + } + (aFindFeature->second)[theAttribute] = std::pair(theSwitchId, theCaseId); +} + +bool Model_ValidatorsFactory::isCase( + FeaturePtr theFeature, std::string theAttribute) +{ + std::map > >::iterator + aFindFeature = myCases.find(theFeature->getKind()); + if (aFindFeature != myCases.end()) { + std::map >::iterator + aFindAttr = aFindFeature->second.find(theAttribute); + if (aFindAttr != aFindFeature->second.end()) { + // the the switch-attribute that contains the case value + AttributeStringPtr aSwitch = theFeature->string(aFindAttr->second.first); + if (aSwitch.get()) { + return aSwitch->value() == aFindAttr->second.second; // the second is the case identifier + } + } + } + return true; // if no additional conditions, this attribute is the case to be validated +}