X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeSelectionList.cpp;h=0643a520bb91a23e620d37c64fefe8413ba3da90;hb=9c54fb01877c455abb5b5ff22e384468f795b328;hp=4a2012a3323ec367dcbdb404f54d706023ce442a;hpb=7ac9a8c74710ef26b9481debf72c8df72c938d44;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeSelectionList.cpp b/src/Model/Model_AttributeSelectionList.cpp index 4a2012a33..0643a520b 100644 --- a/src/Model/Model_AttributeSelectionList.cpp +++ b/src/Model/Model_AttributeSelectionList.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Model_AttributeSelectionList.h // Created: 22 Oct 2014 // Author: Mikhail PONIKAROV @@ -9,17 +11,18 @@ #include "Model_Data.h" #include +#include using namespace std; void Model_AttributeSelectionList::append( - const ResultPtr& theContext, const boost::shared_ptr& theSubShape) + const ResultPtr& theContext, const std::shared_ptr& theSubShape) { int aNewTag = mySize->Get() + 1; TDF_Label aNewLab = mySize->Label().FindChild(aNewTag); - boost::shared_ptr aNewAttr = - boost::shared_ptr(new Model_AttributeSelection(aNewLab)); + std::shared_ptr aNewAttr = + std::shared_ptr(new Model_AttributeSelection(aNewLab)); if (owner()) { aNewAttr->setObject(owner()); } @@ -28,6 +31,35 @@ void Model_AttributeSelectionList::append( owner()->data()->sendAttributeUpdated(this); } +void Model_AttributeSelectionList::append(std::string theNamingName) +{ + int aNewTag = mySize->Get() + 1; + TDF_Label aNewLab = mySize->Label().FindChild(aNewTag); + + std::shared_ptr aNewAttr = + std::shared_ptr(new Model_AttributeSelection(aNewLab)); + if (owner()) { + aNewAttr->setObject(owner()); + } + mySize->Set(aNewTag); + TopAbs_ShapeEnum aType = (TopAbs_ShapeEnum)selectionType(); + string aTypeName; + switch(aType) { + case TopAbs_VERTEX: aTypeName = "VERT"; break; + case TopAbs_EDGE: aTypeName = "EDGE"; break; + case TopAbs_WIRE: aTypeName = "WIRE"; break; + case TopAbs_FACE: aTypeName = "FACE"; break; + case TopAbs_SHELL: aTypeName = "SHEL"; break; + case TopAbs_SOLID: aTypeName = "SOLD"; break; + case TopAbs_COMPOUND: aTypeName = "COMP"; break; + case TopAbs_COMPSOLID: aTypeName = "COMS"; break; + default: + return; // invalid case => empty new attribute + }; + aNewAttr->selectSubShape(aTypeName, theNamingName); + owner()->data()->sendAttributeUpdated(this); +} + int Model_AttributeSelectionList::size() { return mySize->Get(); @@ -43,15 +75,15 @@ void Model_AttributeSelectionList::setSelectionType(int theType) mySelectionType->Set((double) theType); } -boost::shared_ptr +std::shared_ptr Model_AttributeSelectionList::value(const int theIndex) { TDF_Label aLabel = mySize->Label().FindChild(theIndex + 1); // create a new attribute each time, by demand // supporting of old attributes is too slow (synch each time) and buggy on redo // (if attribute is deleted and created, the abort updates attriute and makes the Attr invalid) - boost::shared_ptr aNewAttr = - boost::shared_ptr(new Model_AttributeSelection(aLabel)); + std::shared_ptr aNewAttr = + std::shared_ptr(new Model_AttributeSelection(aLabel)); if (owner()) { aNewAttr->setObject(owner()); }