X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_Feature.cpp;h=7bda5720bb0e1fc8bdb0e28705d1a420bd965c88;hb=2b4f4bf278c841500eb29bb5d204690427b0d56b;hp=00c849fc9e1023abf5aa5c6f842c8852a6055722;hpb=50d85b6bd3f3dd43e11cb6a9ccb3446f5f6d49b6;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_Feature.cpp b/src/SketchPlugin/SketchPlugin_Feature.cpp index 00c849fc9..7bda5720b 100644 --- a/src/SketchPlugin/SketchPlugin_Feature.cpp +++ b/src/SketchPlugin/SketchPlugin_Feature.cpp @@ -2,6 +2,7 @@ #include "SketchPlugin_Sketch.h" #include #include +#include #include SketchPlugin_Feature::SketchPlugin_Feature() @@ -9,27 +10,6 @@ SketchPlugin_Feature::SketchPlugin_Feature() mySketch = 0; } -void SketchPlugin_Feature::setData(boost::shared_ptr theData) -{ - ModelAPI_Feature::setData(theData); - - // find sketch that references to this feature - int aSketches = document()->size("Construction"); - for(int a = 0; a < aSketches && !mySketch; a++) { - boost::shared_ptr aSketch = - boost::dynamic_pointer_cast(document()->feature("Construction", a)); - std::list > aList = - aSketch->data()->reflist(SKETCH_ATTR_FEATURES)->list(); - std::list >::iterator aSub = aList.begin(); - for(; aSub != aList.end(); aSub++) { - if ((*aSub)->data()->isEqual(theData)) { - mySketch = aSketch.get(); - break; - } - } - } -} - void SketchPlugin_Feature::setPreview(const boost::shared_ptr& theShape) { myPreview = theShape; @@ -39,3 +19,27 @@ const boost::shared_ptr& 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 aSketch = boost:: + dynamic_pointer_cast(document()->feature("Construction", a, true)); + if (aSketch) { + std::list aList = + aSketch->data()->reflist(SKETCH_ATTR_FEATURES)->list(); + std::list::iterator aSub = aList.begin(); + for(; aSub != aList.end(); aSub++) { + if ((*aSub)->data()->isEqual(data())) { + mySketch = aSketch.get(); + break; + } + } + } + } + } + return mySketch; +}