X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FModel%2FModel_FeatureValidator.cpp;h=303a465676c90fe08fc484e5a8689856d86db470;hb=45400ecc7d183dd2d2edb875bdb36f8fc031bc2c;hp=b3b1b821687f13ebdadaed93bc9ed4772fde4f02;hpb=38afbd899a8645c83e17f2c24a17a2b7414911b4;p=modules%2Fshaper.git diff --git a/src/Model/Model_FeatureValidator.cpp b/src/Model/Model_FeatureValidator.cpp index b3b1b8216..303a46567 100644 --- a/src/Model/Model_FeatureValidator.cpp +++ b/src/Model/Model_FeatureValidator.cpp @@ -5,34 +5,43 @@ // Author: Vitaly SMETANNIKOV #include +#include #include #include #include #include +#include #include #include bool Model_FeatureValidator::isValid(const std::shared_ptr& theFeature, - const std::list& theArguments) const + const std::list& theArguments, + std::string& theError) const { + static Model_ValidatorsFactory* aValidators = + static_cast(ModelAPI_Session::get()->validators()); + std::shared_ptr aData = theFeature->data(); // "Action" features has no data, but still valid. e.g "Remove Part" - if (!aData) { + if (!aData->isValid()) { + if (!theFeature->isAction()) + theError = "There is no data."; return theFeature->isAction(); } - if (!aData->isValid()) - return false; const std::string kAllTypes = ""; std::list aLtAttributes = aData->attributesIDs(kAllTypes); std::list::iterator it = aLtAttributes.begin(); for (; it != aLtAttributes.end(); it++) { AttributePtr anAttr = aData->attribute(*it); + if (!aValidators->isCase(theFeature, anAttr->id())) + continue; // this attribute is not participated in the current case if (!anAttr->isInitialized()) { // attribute is not initialized std::map >::const_iterator aFeatureFind = myNotObligatory.find(theFeature->getKind()); if (aFeatureFind == myNotObligatory.end() || // and it is obligatory for filling aFeatureFind->second.find(*it) == aFeatureFind->second.end()) { + theError = "Attribute \"" + anAttr->id() + "\" is not initialized."; return false; } }