X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FModel%2FModel_Validator.cpp;h=6795e43e1b2b13cb7387d4ff8e3515534a25ac4b;hb=28d317bd93c0cecba59d648d76209cc3c6200ace;hp=9875f74274a9af41843c9140761b3273f224734d;hpb=509293dabae95f38abae3b8845cc7819736395a0;p=modules%2Fshaper.git diff --git a/src/Model/Model_Validator.cpp b/src/Model/Model_Validator.cpp index 9875f7427..6795e43e1 100644 --- a/src/Model/Model_Validator.cpp +++ b/src/Model/Model_Validator.cpp @@ -4,13 +4,17 @@ // Created: 2 Jul 2014 // Author: Mikhail PONIKAROV -#include -#include -#include +#include "Model_Validator.h" + +#include "Model_AttributeValidator.h" +#include "Model_FeatureValidator.h" + #include -#include -#include #include +#include +#include +#include + #include void Model_ValidatorsFactory::registerValidator(const std::string& theID, @@ -74,56 +78,49 @@ void Model_ValidatorsFactory::assignValidator(const std::string& theID, } void Model_ValidatorsFactory::validators(const std::string& theFeatureID, - std::list& theResult, - std::list >& theArguments) const + Validators& theValidators) const { - std::map::const_iterator aFeature = myFeatures.find(theFeatureID); - if (aFeature != myFeatures.cend()) { - AttrValidators::const_iterator aValIter = aFeature->second.cbegin(); - for (; aValIter != aFeature->second.cend(); aValIter++) { - std::map::const_iterator aFound = - myIDs.find(aValIter->first); - if (aFound == myIDs.end()) { - Events_Error::send(std::string("Validator ") + aValIter->first + " was not registered"); + std::map::const_iterator aFeatureIt = + myFeatures.find(theFeatureID); + if (aFeatureIt != myFeatures.cend()) { + AttrValidators::const_iterator aValidatorsIt = aFeatureIt->second.cbegin(); + for (; aValidatorsIt != aFeatureIt->second.cend(); aValidatorsIt++) { + if (!validator(aValidatorsIt->first)) { + Events_Error::send(std::string("Validator ") + aValidatorsIt->first + " was not registered"); } else { - theResult.push_back(aFound->second); - theArguments.push_back(aValIter->second); + theValidators.push_back(std::make_pair(aValidatorsIt->first, aValidatorsIt->second)); } } } - addDefaultValidators(theResult, theArguments); + addDefaultValidators(theValidators); } -void Model_ValidatorsFactory::validators(const std::string& theFeatureID, - const std::string& theAttrID, - std::list& theValidators, - std::list >& theArguments) const +void Model_ValidatorsFactory::validators(const std::string& theFeatureID, const std::string& theAttrID, + Validators& theValidators) const { - std::map >::const_iterator aFeature = - myAttrs.find(theFeatureID); - if (aFeature != myAttrs.cend()) { - std::map::const_iterator anAttr = aFeature->second.find(theAttrID); - if (anAttr != aFeature->second.end()) { - AttrValidators::const_iterator aValIter = anAttr->second.cbegin(); - for (; aValIter != anAttr->second.cend(); aValIter++) { - std::map::const_iterator aFound = myIDs.find( - aValIter->first); - if (aFound == myIDs.end()) { - Events_Error::send(std::string("Validator ") + aValIter->first + " was not registered"); + std::map >::const_iterator aFeatureIt = + myAttrs.find(theFeatureID); + if (aFeatureIt != myAttrs.cend()) { + std::map::const_iterator anAttrIt = aFeatureIt->second.find(theAttrID); + if (anAttrIt != aFeatureIt->second.end()) { + AttrValidators::const_iterator aValidatorsIt = anAttrIt->second.cbegin(); + for (; aValidatorsIt != anAttrIt->second.cend(); aValidatorsIt++) { + if (!validator(aValidatorsIt->first)) { + Events_Error::send(std::string("Validator ") + aValidatorsIt->first + " was not registered"); } else { - theValidators.push_back(aFound->second); - theArguments.push_back(aValIter->second); + theValidators.push_back(std::make_pair(aValidatorsIt->first, aValidatorsIt->second)); } } } } + addDefaultAttributeValidators(theValidators); } Model_ValidatorsFactory::Model_ValidatorsFactory() : ModelAPI_ValidatorsFactory() { - const static std::string kDefaultId = "Model_FeatureValidator"; - registerValidator(kDefaultId, new Model_FeatureValidator); + registerValidator("Model_FeatureValidator", new Model_FeatureValidator); + registerValidator("Model_AttributeValidator", new Model_AttributeValidator); } const ModelAPI_Validator* Model_ValidatorsFactory::validator(const std::string& theID) const @@ -135,87 +132,139 @@ const ModelAPI_Validator* Model_ValidatorsFactory::validator(const std::string& return NULL; } -void Model_ValidatorsFactory::addDefaultValidators(std::list& theValidators, - std::list >& theArguments) const +void Model_ValidatorsFactory::addDefaultValidators(Validators& theValidators) const { const static std::string kDefaultId = "Model_FeatureValidator"; - std::map::const_iterator it = myIDs.find(kDefaultId); - if(it == myIDs.end()) + if (!validator(kDefaultId)) return; - theValidators.push_back(it->second); - theArguments.push_back(std::list()); + theValidators.push_back(std::make_pair(kDefaultId, std::list())); +} + +void Model_ValidatorsFactory::addDefaultAttributeValidators(Validators& theValidators) const +{ + const static std::string kDefaultId = "Model_AttributeValidator"; + if (!validator(kDefaultId)) + return; + theValidators.push_back(std::make_pair(kDefaultId, std::list())); } bool Model_ValidatorsFactory::validate(const std::shared_ptr& theFeature) const { - const static std::string kDefaultId = "Model_FeatureValidator"; + std::shared_ptr aData = std::dynamic_pointer_cast(theFeature->data()); + if (aData.get() && aData->isValid()) { + if (aData->execState() == ModelAPI_StateDone) + aData->eraseErrorString(); // no error => erase the information string + } else { + return false; // feature is broken, already not presented in the data structure + } + // check feature validators first - std::map::const_iterator aFeature = - myFeatures.find(theFeature->getKind()); - if (aFeature != myFeatures.end()) { - AttrValidators::const_iterator aValidator = aFeature->second.begin(); - for(; aValidator != aFeature->second.end(); aValidator++) { - std::map::const_iterator aValFind = - myIDs.find(aValidator->first); - if (aValFind == myIDs.end()) { - Events_Error::send(std::string("Validator ") + aValidator->first + " was not registered"); - continue; - } + Validators aValidators; + validators(theFeature->getKind(), aValidators); + + if (!aValidators.empty()) { + Validators::const_iterator aValidatorIt = aValidators.cbegin(); + for(; aValidatorIt != aValidators.cend(); aValidatorIt++) { + const std::string& aValidatorID = aValidatorIt->first; + const std::list& anArguments = aValidatorIt->second; + // validators() checks invalid validator names + //if (!aValidator) { + // Events_Error::send(std::string("Validator ") + aValidatorID + " was not registered"); + // continue; + //} const ModelAPI_FeatureValidator* aFValidator = - dynamic_cast(aValFind->second); + dynamic_cast(validator(aValidatorID)); if (aFValidator) { - if (!aFValidator->isValid(theFeature, aValidator->second)) + std::string anError; + if (!aFValidator->isValid(theFeature, anArguments, anError)) { + if (anError.empty()) + anError = "Unknown error."; + anError = aValidatorID + ": " + anError; + theFeature->setError(anError, false); + theFeature->data()->execState(ModelAPI_StateInvalidArgument); return false; + } } } } - // check default validator - std::map::const_iterator aDefaultVal = myIDs.find(kDefaultId); - if(aDefaultVal != myIDs.end()) { - static const std::list anEmptyArgList; - const ModelAPI_FeatureValidator* aFValidator = - dynamic_cast(aDefaultVal->second); - if (aFValidator) { - if (!aFValidator->isValid(theFeature, anEmptyArgList)) - return false; - } - } - + // The default validator was retrned by validators() and was checked in previous cycle + //// check default validator + //std::map::const_iterator aDefaultVal = myIDs.find(kDefaultId); + //if(aDefaultVal != myIDs.end()) { + // static const std::list anEmptyArgList; + // const ModelAPI_FeatureValidator* aFValidator = + // dynamic_cast(aDefaultVal->second); + // if (aFValidator) { + // std::string anError; + // if (!aFValidator->isValid(theFeature, anEmptyArgList, anError)) { + // if (anError.empty()) + // anError = "Unknown error."; + // anError = "Feature invalidated by \"" + kDefaultId + "\" with error: " + anError; + // theFeature->setError(anError, false); + // theFeature->data()->execState(ModelAPI_StateInvalidArgument); + // return false; + // } + // } + //} + // check all attributes for validity - 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()); - if (aFeatureIter != myAttrs.cend()) { - std::list aLtAttributes = aData->attributesIDs(kAllTypes); - std::list::iterator anAttrIter = aLtAttributes.begin(); - for (; anAttrIter != aLtAttributes.end(); anAttrIter++) { - std::map::const_iterator anAttr = - aFeatureIter->second.find(*anAttrIter); - if (anAttr != aFeatureIter->second.end()) { - AttrValidators::const_iterator aValIter = anAttr->second.cbegin(); - for (; aValIter != anAttr->second.cend(); aValIter++) { - std::map::const_iterator aFound = myIDs.find( - aValIter->first); - if (aFound == myIDs.end()) { - Events_Error::send(std::string("Validator ") + aValIter->first + " was not registered"); - } else { - const ModelAPI_AttributeValidator* anAttrValidator = - dynamic_cast(aFound->second); - if (anAttrValidator) { - AttributePtr anAttribute = theFeature->data()->attribute(*anAttrIter); - if (!anAttrValidator->isValid(anAttribute, aValIter->second)) { - return false; - } - } - } - } - } - } + std::list aLtAttributes = aData->attributesIDs(kAllTypes); + std::list::const_iterator anAttrIt = aLtAttributes.cbegin(); + for (; anAttrIt != aLtAttributes.cend(); anAttrIt++) { + const std::string& anAttributeID = *anAttrIt; + AttributePtr anAttribute = theFeature->data()->attribute(anAttributeID); + + std::string aValidatorID; + std::string anError; + if (!validate(anAttribute, aValidatorID, anError)) { + if (anError.empty()) + anError = "Unknown error."; + anError = anAttributeID + " - " + aValidatorID + ": " + anError; + theFeature->setError(anError, false); + theFeature->data()->execState(ModelAPI_StateInvalidArgument); + return false; + } } + + return true; +} + +bool Model_ValidatorsFactory::validate(const std::shared_ptr& theAttribute, + std::string& theValidator, + std::string& theError) const +{ + FeaturePtr aFeature = ModelAPI_Feature::feature(theAttribute->owner()); + if (!aFeature.get()) { + theValidator = "Model_ValidatorsFactory"; + theError = "Attribute has no feature."; + return false; + } + + // skip not-case attributes, that really may be invalid (issue 671) + if (!const_cast(this)->isCase(aFeature, theAttribute->id())) + return true; + + Validators aValidators; + validators(aFeature->getKind(), theAttribute->id(), aValidators); + + Validators::iterator aValidatorIt = aValidators.begin(); + for (; aValidatorIt != aValidators.end(); ++aValidatorIt) { + const std::string& aValidatorID = aValidatorIt->first; + const std::list& anArguments = aValidatorIt->second; + const ModelAPI_AttributeValidator* anAttrValidator = + dynamic_cast(validator(aValidatorID)); + if (!anAttrValidator) + continue; + if (!anAttrValidator->isValid(theAttribute, anArguments, theError)) { + theValidator = aValidatorID; + return false; + } + } + return true; } @@ -265,28 +314,36 @@ bool Model_ValidatorsFactory::isConcealed(std::string theFeature, std::string th void Model_ValidatorsFactory::registerCase(std::string theFeature, std::string theAttribute, std::string theSwitchId, std::string theCaseId) { - std::map > >::iterator - aFindFeature = myCases.find(theFeature); + std::map > > > + ::iterator aFindFeature = myCases.find(theFeature); if (aFindFeature == myCases.end()) { - myCases[theFeature] = std::map >(); + myCases[theFeature] = std::map > >(); aFindFeature = myCases.find(theFeature); } - (aFindFeature->second)[theAttribute] = std::pair(theSwitchId, theCaseId); + std::map > >::iterator aFindAttrID = + aFindFeature->second.find(theAttribute); + if (aFindAttrID == aFindFeature->second.end()) { + aFindFeature->second[theAttribute] = + std::pair >(theSwitchId, std::set()); + aFindAttrID = aFindFeature->second.find(theAttribute); + } + aFindAttrID->second.second.insert(theCaseId); } -bool Model_ValidatorsFactory::isCase( - FeaturePtr theFeature, std::string theAttribute) +bool Model_ValidatorsFactory::isCase(FeaturePtr theFeature, std::string theAttribute) { - std::map > >::iterator - aFindFeature = myCases.find(theFeature->getKind()); + 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()) { + std::map > >::iterator + aFindAttrID = aFindFeature->second.find(theAttribute); + if (aFindAttrID != aFindFeature->second.end()) { // the the switch-attribute that contains the case value - AttributeStringPtr aSwitch = theFeature->string(aFindAttr->second.first); + AttributeStringPtr aSwitch = theFeature->string(aFindAttrID->second.first); if (aSwitch.get()) { - return aSwitch->value() == aFindAttr->second.second; // the second is the case identifier + // the second has the case identifier + return aFindAttrID->second.second.find(aSwitch->value()) != + aFindAttrID->second.second.end(); } } }