Salome HOME
refs #222 - correction to do not select the same parameters in the distance constraint.
[modules/shaper.git] / src / SketchPlugin / SketchPlugin_Feature.cpp
index 6f8f41af8d3d86e28279af7e43b3ae04e3931c1e..2d46d8ca14e2bb79a1c3a29564ba528bd59b1edb 100644 (file)
@@ -4,46 +4,44 @@
 #include <ModelAPI_Data.h>
 #include <ModelAPI_Object.h>
 #include <ModelAPI_AttributeRefList.h>
+#include <ModelAPI_ResultConstruction.h>
 
 SketchPlugin_Feature::SketchPlugin_Feature()
 {
   mySketch = 0;
 }
 
-void SketchPlugin_Feature::setPreview(const boost::shared_ptr<GeomAPI_Shape>& theShape)
-{
-  myPreview = theShape;
-}
-
-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<ModelAPI_Object> anObj = 
-        boost::dynamic_pointer_cast<ModelAPI_Object>(document()->feature("Construction", a));
-      if (anObj) {
-        boost::shared_ptr<SketchPlugin_Sketch> aSketch = 
-          boost::dynamic_pointer_cast<SketchPlugin_Sketch>(anObj->featureRef());
-        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;
-            }
-          }
-        }
+    const std::set<AttributePtr>& aBackRefs = data()->refsToMe();
+    std::set<AttributePtr>::const_iterator aBackRef = aBackRefs.begin();
+    for(; aBackRef != aBackRefs.end(); aBackRef++) {
+      boost::shared_ptr<SketchPlugin_Sketch> aSketch = 
+        boost::dynamic_pointer_cast<SketchPlugin_Sketch>((*aBackRef)->owner());
+      if (aSketch) {
+        mySketch = aSketch.get();
+        break;
       }
     }
   }
   return mySketch;
 }
+
+AISObjectPtr SketchPlugin_Feature::simpleAISObject(boost::shared_ptr<ModelAPI_Result> theRes,
+                                                   AISObjectPtr thePrevious)
+{
+  boost::shared_ptr<ModelAPI_ResultConstruction> aConstr = boost::dynamic_pointer_cast<
+      ModelAPI_ResultConstruction>(theRes);
+
+  boost::shared_ptr<GeomAPI_Shape> aPreview;
+  if (aConstr)
+    aPreview = aConstr->shape();
+
+  AISObjectPtr aResult = thePrevious;
+  if (!aResult)
+    aResult = AISObjectPtr(new GeomAPI_AISObject());
+  aResult->createShape(aPreview);
+  return aResult;
+}