X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_Feature.cpp;h=7bda5720bb0e1fc8bdb0e28705d1a420bd965c88;hb=2b4f4bf278c841500eb29bb5d204690427b0d56b;hp=e7d9d292ac90e44937429ac44a5ea2fb23052938;hpb=37bf139347283d16d59b08079d52be5f6f29a38c;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_Feature.cpp b/src/SketchPlugin/SketchPlugin_Feature.cpp index e7d9d292a..7bda5720b 100644 --- a/src/SketchPlugin/SketchPlugin_Feature.cpp +++ b/src/SketchPlugin/SketchPlugin_Feature.cpp @@ -1,4 +1,14 @@ #include "SketchPlugin_Feature.h" +#include "SketchPlugin_Sketch.h" +#include +#include +#include +#include + +SketchPlugin_Feature::SketchPlugin_Feature() +{ + mySketch = 0; +} void SketchPlugin_Feature::setPreview(const boost::shared_ptr& theShape) { @@ -9,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; +}