Salome HOME
Merge branch 'SketchSolver'
[modules/shaper.git] / src / SketchPlugin / SketchPlugin_Feature.cpp
index e7d9d292ac90e44937429ac44a5ea2fb23052938..ae771b5567b1dff3cc71ac5f52d9c4b15ff95969 100644 (file)
@@ -1,4 +1,14 @@
 #include "SketchPlugin_Feature.h"
+#include "SketchPlugin_Sketch.h"
+#include <ModelAPI_Document.h>
+#include <ModelAPI_Data.h>
+#include <ModelAPI_Object.h>
+#include <ModelAPI_AttributeRefList.h>
+
+SketchPlugin_Feature::SketchPlugin_Feature()
+{
+  mySketch = 0;
+}
 
 void SketchPlugin_Feature::setPreview(const boost::shared_ptr<GeomAPI_Shape>& theShape)
 {
@@ -9,3 +19,27 @@ const boost::shared_ptr<GeomAPI_Shape>& SketchPlugin_Feature::getPreview() const
 {
   return myPreview;
 }
+
+SketchPlugin_Sketch* SketchPlugin_Feature::sketch()
+{
+  if (!mySketch) {
+    // find sketch that references to this feature
+    int aSketches = document()->size("Construction");
+    for(int a = 0; a < aSketches && !mySketch; a++) {
+      boost::shared_ptr<SketchPlugin_Sketch> aSketch = boost::
+        dynamic_pointer_cast<SketchPlugin_Sketch>(document()->feature("Construction", a, true));
+      if (aSketch) {
+        std::list<boost::shared_ptr<ModelAPI_Feature> > aList = 
+          aSketch->data()->reflist(SKETCH_ATTR_FEATURES)->list();
+        std::list<boost::shared_ptr<ModelAPI_Feature> >::iterator aSub = aList.begin();
+        for(; aSub != aList.end(); aSub++) {
+          if ((*aSub)->data()->isEqual(data())) {
+            mySketch = aSketch.get();
+            break;
+          }
+        }
+      }
+    }
+  }
+  return mySketch;
+}