]> SALOME platform Git repositories - modules/shaper.git/commitdiff
Salome HOME
Issue #222 Fatal error for 0 distance
authornds <natalia.donis@opencascade.com>
Wed, 28 Jan 2015 11:38:54 +0000 (14:38 +0300)
committernds <natalia.donis@opencascade.com>
Wed, 28 Jan 2015 11:38:54 +0000 (14:38 +0300)
The point on the circle line should not use this circle as an object in the distance operation.
There was additional crash by selecting it.

src/SketchPlugin/SketchPlugin_Validators.cpp

index b53102af2a268799729f716ecf5ffde12850d3c6..29bdf3c27310df0ba7abadc7ca882ea353ef4f85 100644 (file)
@@ -22,16 +22,18 @@ bool SketchPlugin_DistanceAttrValidator::isValid(const FeaturePtr& theFeature,
   SessionPtr aMgr = ModelAPI_Session::get();
   ModelAPI_ValidatorsFactory* aFactory = aMgr->validators();
 
-  // If the object is not a line then it is accepted
-  const ModelAPI_ResultValidator* aLineValidator =
-      dynamic_cast<const ModelAPI_ResultValidator*>(aFactory->validator("SketchPlugin_ResultLine"));
-  bool aLineValid = aLineValidator->isValid(theObject);
-
   const ModelAPI_ResultValidator* anArcValidator =
       dynamic_cast<const ModelAPI_ResultValidator*>(aFactory->validator("SketchPlugin_ResultArc"));
   bool anArcValid = anArcValidator->isValid(theObject);
+  if (anArcValid)
+    return false;
 
-  if (!aLineValid && !anArcValid)
+
+  // If the object is not a line then it is accepted
+  const ModelAPI_ResultValidator* aLineValidator =
+      dynamic_cast<const ModelAPI_ResultValidator*>(aFactory->validator("SketchPlugin_ResultLine"));
+  bool aLineValid = aLineValidator->isValid(theObject);
+  if (!aLineValid)
     return true;
 
   // If it is a line then we have to check that first attribute id not a line