]> SALOME platform Git repositories - modules/shaper.git/commitdiff
Salome HOME
An attempt to correct the linux runtime problem after the previous integration.
authornds <natalia.donis@opencascade.com>
Wed, 11 Feb 2015 11:15:18 +0000 (14:15 +0300)
committernds <natalia.donis@opencascade.com>
Wed, 11 Feb 2015 11:15:18 +0000 (14:15 +0300)
src/SketchPlugin/SketchPlugin_Feature.cpp
src/SketchPlugin/SketchPlugin_Feature.h

index b89f5d42563a44a380f72f4cdbc9f7fd1c62c1af..5842df8a0968939413d98fd409be090d7e116fa9 100644 (file)
@@ -8,20 +8,21 @@
 #include <ModelAPI_AttributeRefList.h>
 #include <ModelAPI_ResultConstruction.h>
 
+/// It is important.
+///
+/// Before writing a new method implementation in this file, please check the next rule:
+/// exported public methods must not be implemented in this source file. They should be inline and
+/// placed in the header file.
+/// Because it leads to the runtime problem on the Linux OS.
+///
+/// The reason is that this is an abstract interface. An interface of this class can be used in
+/// outside libraries through casting without a link to the current library.
+
 SketchPlugin_Feature::SketchPlugin_Feature()
 {
   mySketch = 0;
 }
 
-void SketchPlugin_Feature::erase()
-{
-  SketchPlugin_Sketch* aSketch = sketch();
-  if (aSketch)
-    aSketch->removeFeature(this);
-
-  ModelAPI_Feature::erase();
-}
-
 SketchPlugin_Sketch* SketchPlugin_Feature::sketch()
 {
   if (!mySketch) {
index 5174eff40940cd9ccf9f7d9c1decc9e4a2333efa..7a50ef4e3369b1cc7b372a6ff1c36be91012851e 100644 (file)
@@ -67,8 +67,8 @@ class SketchPlugin_Feature : public ModelAPI_Feature, public GeomAPI_ICustomPrs
   /// Customize presentation of the feature
   virtual void customisePresentation(AISObjectPtr thePrs)
   {
-    // if this is an edge or vertex
-    if ((thePrs->getShapeType() == 6) || (thePrs->getShapeType() == 7)) {
+    // if this is an edge
+    if (thePrs->getShapeType() == 6) {
       thePrs->setWidth(3);
       if (isExternal())
         thePrs->setColor(0,255,0);
@@ -79,7 +79,14 @@ class SketchPlugin_Feature : public ModelAPI_Feature, public GeomAPI_ICustomPrs
   }
 
   /// removes also all sub-sketch elements
-  SKETCHPLUGIN_EXPORT virtual void erase();
+  SKETCHPLUGIN_EXPORT virtual void erase()
+  {
+    /*SketchPlugin_Sketch* aSketch = sketch();
+    if (aSketch)
+      aSketch->removeFeature(this);
+      */
+    ModelAPI_Feature::erase();
+  }
 
   /// Returns the sketch of this feature
   SketchPlugin_Sketch* sketch();