X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_Validator.cpp;h=c2c994da9cd65dc1b194115c8250aa524760ae1c;hb=6268ce56824c1df106da799af34f4575f247061a;hp=cc3a612a50d19752eae437181a03df9d3122bf75;hpb=9e869ede4d8c56262bb20534543c2bf56cd6a91b;p=modules%2Fshaper.git diff --git a/src/Model/Model_Validator.cpp b/src/Model/Model_Validator.cpp index cc3a612a5..c2c994da9 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 @@ -88,7 +90,7 @@ void Model_ValidatorsFactory::validators(const std::string& theFeatureID, } } } - addDefaultValidators(theResult); + addDefaultValidators(theResult, theArguments); } void Model_ValidatorsFactory::validators(const std::string& theFeatureID, @@ -132,13 +134,15 @@ 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 std::shared_ptr& theFeature) const @@ -175,10 +179,12 @@ bool Model_ValidatorsFactory::validate(const std::shared_ptr& return false; } } + // check all attributes for validity std::shared_ptr aData = theFeature->data(); - if (!aData || !aData->isValid()) - return false; + // 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()); @@ -224,6 +230,19 @@ void Model_ValidatorsFactory::registerNotObligatory(std::string theFeature, std: } } +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);