X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FFeaturesPlugin%2FFeaturesPlugin_ExtrusionCut.cpp;h=f7344b0a462b2f68f8837430a66d09d621d4a2d8;hb=7be6ffd35a5a91e67aec25716e46b44f72b985b2;hp=09d56a48671f14f59a05d69dbcf5c858a93ebb1c;hpb=bc040d7778dfca67e24a0452ce41f88417799adb;p=modules%2Fshaper.git diff --git a/src/FeaturesPlugin/FeaturesPlugin_ExtrusionCut.cpp b/src/FeaturesPlugin/FeaturesPlugin_ExtrusionCut.cpp old mode 100755 new mode 100644 index 09d56a486..f7344b0a4 --- a/src/FeaturesPlugin/FeaturesPlugin_ExtrusionCut.cpp +++ b/src/FeaturesPlugin/FeaturesPlugin_ExtrusionCut.cpp @@ -1,96 +1,20 @@ // Copyright (C) 2014-20xx CEA/DEN, EDF R&D // File: FeaturesPlugin_ExtrusionCut.cpp -// Created: 12 May 2015 +// Created: 11 June 2015 // Author: Dmitry Bobylev -#include - -#include -#include -#include -#include -#include -#include -#include +#include "FeaturesPlugin_ExtrusionCut.h" //================================================================================================= FeaturesPlugin_ExtrusionCut::FeaturesPlugin_ExtrusionCut() { -} - -//================================================================================================= -void FeaturesPlugin_ExtrusionCut::initAttributes() -{ - - data()->addAttribute(SKETCH_OBJECT_ID(), ModelAPI_AttributeReference::typeId()); - - data()->addAttribute(FROM_OBJECT_ID(), ModelAPI_AttributeSelection::typeId()); - data()->addAttribute(FROM_SIZE_ID(), ModelAPI_AttributeDouble::typeId()); - - data()->addAttribute(TO_OBJECT_ID(), ModelAPI_AttributeSelection::typeId()); - data()->addAttribute(TO_SIZE_ID(), ModelAPI_AttributeDouble::typeId()); - - ModelAPI_Session::get()->validators()->registerNotObligatory(getKind(), FeaturesPlugin_ExtrusionCut::FROM_OBJECT_ID()); - ModelAPI_Session::get()->validators()->registerNotObligatory(getKind(), FeaturesPlugin_ExtrusionCut::TO_OBJECT_ID()); - - data()->addAttribute(CUTLIST_ID(), ModelAPI_AttributeSelectionList::typeId()); - - // extrusion works with faces always - AttributeSelectionListPtr aSelection = data()->selectionList(CUTLIST_ID()); - aSelection->setSelectionType("SOLID"); -} - - -std::shared_ptr FeaturesPlugin_ExtrusionCut::addFeature(std::string theID) -{ - std::shared_ptr aNew = document()->addFeature(theID, false); - if (aNew) { - data()->reference(SKETCH_OBJECT_ID())->setValue(aNew); - } - // set as current also after it becomes sub to set correctly enabled for other sketch subs - //document()->setCurrentFeature(aNew, false); - return aNew; -} - - -int FeaturesPlugin_ExtrusionCut::numberOfSubs() const -{ - ObjectPtr aObj = data()->reference(SKETCH_OBJECT_ID())->value(); - return aObj.get()? 1 : 0; -} - -std::shared_ptr FeaturesPlugin_ExtrusionCut::subFeature(const int theIndex) const -{ - if (theIndex == 0) - return std::dynamic_pointer_cast(data()->reference(SKETCH_OBJECT_ID())->value()); - return std::shared_ptr(); -} - -int FeaturesPlugin_ExtrusionCut::subFeatureId(const int theIndex) const -{ - std::shared_ptr aFeature = subFeature(theIndex); - if (aFeature.get()) - return aFeature->data()->featureId(); - return -1; -} - -bool FeaturesPlugin_ExtrusionCut::isSub(ObjectPtr theObject) const -{ - // check is this feature of result - FeaturePtr aFeature = std::dynamic_pointer_cast(theObject); - if (!aFeature) - return false; - - ObjectPtr aSub = data()->reference(SKETCH_OBJECT_ID())->value(); - return aSub == theObject; -} - -void FeaturesPlugin_ExtrusionCut::removeFeature(std::shared_ptr theFeature) -{ + myFeature = this; + myOperationType = BOOL_CUT; } //================================================================================================= void FeaturesPlugin_ExtrusionCut::execute() { + executeCompositeBoolean(); }