]> SALOME platform Git repositories - modules/shaper.git/commitdiff
Salome HOME
Issue #1223 Conflicting constraints not raised: correction of error text over Apply
authornds <nds@opencascade.com>
Wed, 20 Jan 2016 13:36:12 +0000 (16:36 +0300)
committerdbv <dbv@opencascade.com>
Tue, 16 Feb 2016 14:04:24 +0000 (17:04 +0300)
If the feature is Composite and error is StateInvalidArgument, error text should include error of first invalid sub-feature.

src/ModelAPI/ModelAPI_Tools.cpp

index 1b618562d6e8c10dc3b3c6daa61a59574a8fbc0e..20df8a89d2e5a36255d32f9308de5de5ec237022 100755 (executable)
@@ -52,8 +52,26 @@ std::string getFeatureError(const FeaturePtr& theFeature)
   if (anError.empty()) {
     bool isDone = ( theFeature->data()->execState() == ModelAPI_StateDone
                  || theFeature->data()->execState() == ModelAPI_StateMustBeUpdated );
-    if (!isDone)
+    if (!isDone) {
       anError = toString(theFeature->data()->execState());
+      // If the feature is Composite and error is StateInvalidArgument,
+      // error text should include error of first invalid sub-feature. Otherwise
+      // it is not clear what is the reason of the invalid argument.
+      if (theFeature->data()->execState() == ModelAPI_StateInvalidArgument) {
+        CompositeFeaturePtr aComposite =
+                    std::dynamic_pointer_cast<ModelAPI_CompositeFeature>(theFeature);
+        if (aComposite) {
+          for (int i = 0, aSize = aComposite->numberOfSubs(); i < aSize; i++) {
+            FeaturePtr aSubFeature = aComposite->subFeature(i);
+            std::string aSubFeatureError = getFeatureError(aSubFeature);
+            if (!aSubFeatureError.empty()) {
+              anError = anError + " in " + aSubFeature->getKind() + ".\n" + aSubFeatureError;
+              break;
+            }
+          }
+        }
+      }
+    }
   }
 
   return anError;