-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
-
-// File: Model_Validator.cpp
-// Created: 2 Jul 2014
-// Author: Mikhail PONIKAROV
+// Copyright (C) 2014-2017 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or
+// email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
+//
#include "Model_Validator.h"
#include <ModelAPI_Result.h>
#include <Model_Data.h>
+#include <Config_Translator.h>
+
#include <Events_InfoMessage.h>
void Model_ValidatorsFactory::registerValidator(const std::string& theID,
myFeatures[theFeatureID] = AttrValidators();
}
if (myFeatures[theFeatureID].find(theID) != myFeatures[theFeatureID].end()) {
- //Events_Error::send(std::string("Validator ") + theID +
+ //Events_Error::send(std::string("Validator ") + theID +
// " for feature " + theFeatureID + "is already registered");
} else {
myFeatures[theFeatureID][theID] = std::list<std::string>();
}
if (myFeatures[theFeatureID].find(theID) != myFeatures[theFeatureID].end()) {
- //Events_Error::send(std::string("Validator ") + theID +
+ //Events_Error::send(std::string("Validator ") + theID +
// " for feature " + theFeatureID + "is already registered");
} else {
myFeatures[theFeatureID][theID] = theArguments;
void Model_ValidatorsFactory::validators(const std::string& theFeatureID,
Validators& theValidators) const
{
- std::map<std::string, AttrValidators>::const_iterator aFeatureIt =
+ std::map<std::string, AttrValidators>::const_iterator aFeatureIt =
myFeatures.find(theFeatureID);
if (aFeatureIt != myFeatures.cend()) {
AttrValidators::const_iterator aValidatorsIt = aFeatureIt->second.cbegin();
addDefaultValidators(theValidators);
}
-void Model_ValidatorsFactory::validators(const std::string& theFeatureID,
+void Model_ValidatorsFactory::validators(const std::string& theFeatureID,
const std::string& theAttrID,
Validators& theValidators) const
{
- std::map<std::string, std::map<std::string, AttrValidators> >::const_iterator aFeatureIt =
+ std::map<std::string, std::map<std::string, AttrValidators> >::const_iterator aFeatureIt =
myAttrs.find(theFeatureID);
if (aFeatureIt != myAttrs.cend()) {
std::map<std::string, AttrValidators>::const_iterator anAttrIt =
for(; aValidatorIt != aValidators.cend(); aValidatorIt++) {
const std::string& aValidatorID = aValidatorIt->first;
const std::list<std::string>& 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 =
+ const ModelAPI_FeatureValidator* aFValidator =
dynamic_cast<const ModelAPI_FeatureValidator*>(validator(aValidatorID));
if (aFValidator) {
Events_InfoMessage anError;
if (!aFValidator->isValid(theFeature, anArguments, anError)) {
if (anError.empty())
anError = "Unknown error.";
- anError = aValidatorID + ": " + anError.messageString();
- theFeature->setError(anError.messageString(), false);
+ if (anError.context().empty()) {
+ anError.setContext(theFeature->getKind() + ":" + aValidatorID);
+ }
+ theFeature->setError(Config_Translator::translate(anError), false, false);
theFeature->data()->execState(ModelAPI_StateInvalidArgument);
return false;
}
}
}
}
- // The default validator was retrned by validators() and was checked in previous cycle
- //// check default validator
- //std::map<std::string, ModelAPI_Validator*>::const_iterator aDefaultVal = myIDs.find(kDefaultId);
- //if(aDefaultVal != myIDs.end()) {
- // static const std::list<std::string> anEmptyArgList;
- // const ModelAPI_FeatureValidator* aFValidator =
- // dynamic_cast<const ModelAPI_FeatureValidator*>(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
- // Validity of data is checked by "Model_FeatureValidator" (kDefaultId)
- // if (!aData || !aData->isValid())
- // return false;
static const std::string kAllTypes = "";
std::list<std::string> aLtAttributes = aData->attributesIDs(kAllTypes);
std::list<std::string>::const_iterator anAttrIt = aLtAttributes.cbegin();
for (; anAttrIt != aLtAttributes.cend(); anAttrIt++) {
- const std::string& anAttributeID = *anAttrIt;
+ const std::string& anAttributeID = *anAttrIt;
AttributePtr anAttribute = theFeature->data()->attribute(anAttributeID);
std::string aValidatorID;
if (!validate(anAttribute, aValidatorID, anError)) {
if (anError.empty())
anError = "Unknown error.";
- anError = anAttributeID + " - " + aValidatorID + ": " + anError.messageString();
- theFeature->setError(anError.messageString(), false);
+ if (anError.context().empty()) {
+ anError.setContext(theFeature->getKind() + ":" + anAttributeID + ":" + aValidatorID);
+ }
+ theFeature->setError(Config_Translator::translate(anError), false, false);
theFeature->data()->execState(ModelAPI_StateInvalidArgument);
return false;
- }
+ }
}
return true;
if (!anAttrValidator->isValid(theAttribute, anArguments, theError)) {
theValidator = aValidatorID;
return false;
- }
+ }
}
return true;
}
-void Model_ValidatorsFactory::registerNotObligatory(std::string theFeature,
+void Model_ValidatorsFactory::registerNotObligatory(std::string theFeature,
std::string theAttribute)
{
const static std::string kDefaultId = "Model_FeatureValidator";
return aFind != myConcealed.end() && aFind->second.find(theAttribute) != aFind->second.end();
}
-void Model_ValidatorsFactory::registerUnconcealment(std::shared_ptr<ModelAPI_Result> theUnconcealed,
- std::shared_ptr<ModelAPI_Feature> theCanceledFeat)
-{
- if (myUnconcealed.find(theUnconcealed) == myUnconcealed.end()) {
- myUnconcealed[theUnconcealed] = std::list<std::shared_ptr<ModelAPI_Feature> >();
- }
- myUnconcealed[theUnconcealed].push_back(theCanceledFeat);
- std::dynamic_pointer_cast<Model_Data>(theUnconcealed->data())->updateConcealmentFlag();
-}
-
-void Model_ValidatorsFactory::disableUnconcealment(std::shared_ptr<ModelAPI_Result> theUnconcealed,
- std::shared_ptr<ModelAPI_Feature> theCanceledFeat)
-{
- std::map<std::shared_ptr<ModelAPI_Result>, std::list<std::shared_ptr<ModelAPI_Feature> > >
- ::iterator aResFound = myUnconcealed.find(theUnconcealed);
- if (aResFound != myUnconcealed.end()) {
- std::list<std::shared_ptr<ModelAPI_Feature> >::iterator anIter = aResFound->second.begin();
- for(; anIter != aResFound->second.end(); anIter++) {
- if (*anIter == theCanceledFeat) {
- aResFound->second.erase(anIter);
- std::dynamic_pointer_cast<Model_Data>(theUnconcealed->data())->updateConcealmentFlag();
- break;
- }
- }
- }
-}
-
-bool Model_ValidatorsFactory::isUnconcealed(std::shared_ptr<ModelAPI_Result> theUnconcealed,
- std::shared_ptr<ModelAPI_Feature> theCanceledFeat)
-{
- std::map<std::shared_ptr<ModelAPI_Result>, std::list<std::shared_ptr<ModelAPI_Feature> > >
- ::iterator aResFound = myUnconcealed.find(theUnconcealed);
- if (aResFound != myUnconcealed.end()) {
- std::list<std::shared_ptr<ModelAPI_Feature> >::iterator aFeatIter = aResFound->second.begin();
- for(; aFeatIter != aResFound->second.end(); aFeatIter++) {
- if (aFeatIter->get()) {
- if ((*aFeatIter)->isDisabled()) continue;
- if (*aFeatIter == theCanceledFeat)
- return true; // this is exactly canceled
- if (theCanceledFeat->document()->isLater(*aFeatIter, theCanceledFeat))
- return true; // if unconcealed feature (from the list) is later than concealed
- } else
- return true; // empty attribute means that everything is canceled
- }
- }
- return false;
-}
-
void Model_ValidatorsFactory::registerCase(std::string theFeature, std::string theAttribute,
const std::list<std::pair<std::string, std::string> >& theCases)
{
}
return anInCase; // if no additional conditions, this attribute is the case to be validated
}
+
+void Model_ValidatorsFactory::registerMainArgument(std::string theFeature,
+ std::string theAttribute)
+{
+ std::map<std::string, std::string>::iterator aFound = myMainArgument.find(theFeature);
+ if (aFound == myMainArgument.end())
+ myMainArgument[theFeature] = theAttribute;
+}
+
+bool Model_ValidatorsFactory::isMainArgument(std::string theFeature, std::string theAttribute)
+{
+ std::map<std::string, std::string>::iterator aFound = myMainArgument.find(theFeature);
+ return aFound != myMainArgument.end() && aFound->second == theAttribute;
+}