X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSetPlugin%2FPartSetPlugin_Part.cpp;h=4eee01130ea56cad1a35f415f88a224171b7bc55;hb=f9426a402de748e9d13085856a7cf72a3659135d;hp=df8b645109bd5d87b6315a15134a99cb5bc9ac66;hpb=932fc1c1622a107f55ab03b3242691961ef28c76;p=modules%2Fshaper.git diff --git a/src/PartSetPlugin/PartSetPlugin_Part.cpp b/src/PartSetPlugin/PartSetPlugin_Part.cpp index df8b64510..4eee01130 100644 --- a/src/PartSetPlugin/PartSetPlugin_Part.cpp +++ b/src/PartSetPlugin/PartSetPlugin_Part.cpp @@ -1,8 +1,22 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -// File: PartSetPlugin_Part.cxx -// Created: 27 Mar 2014 -// Author: Mikhail PONIKAROV +// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or +// email : webmaster.salome@opencascade.com +// #include "PartSetPlugin_Part.h" #include "ModelAPI_Session.h" @@ -28,7 +42,9 @@ void PartSetPlugin_Part::execute() setResult(aResult); // do not activate part by simple execution if it is not loaded yet: it must be explicitly // activated for this - if (!ModelAPI_Session::get()->isLoadByDemand(aResult->data()->name())) { + std::shared_ptr aDocRef = + aResult->data()->document(ModelAPI_ResultPart::DOC_REF()); + if (!ModelAPI_Session::get()->isLoadByDemand(aResult->data()->name(), aDocRef->docId())) { // On undo/redo creation of the part result the Object Browser must get creation event // earlier that activation of this part event (otherwise the crash is produced) // So, send a creation event earlier, without any grouping @@ -112,7 +128,8 @@ void PartSetPlugin_Part::erase() { ResultPartPtr aResult = std::dynamic_pointer_cast(firstResult()); if (aResult.get()) { DocumentPtr aDoc = aResult->partDoc(); - aDoc->eraseAllFeatures(); + if (aDoc.get()) + aDoc->eraseAllFeatures(); } ModelAPI_Feature::erase(); }