X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_Document.h;h=1dec08f14434d02d8557ee83fd2b936cb8f6dabe;hb=06e7f5859095193fc7f498bd89a7d28009794f53;hp=277c822ba629730adc39a796a6a78192f72afcc2;hpb=77d6e03555d0d46232e09ace4178f66f8c9b40ee;p=modules%2Fshaper.git diff --git a/src/Model/Model_Document.h b/src/Model/Model_Document.h index 277c822ba..1dec08f14 100644 --- a/src/Model/Model_Document.h +++ b/src/Model/Model_Document.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// Copyright (C) 2014-2023 CEA, EDF // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -106,6 +106,8 @@ class Model_Document : public ModelAPI_Document MODEL_EXPORT virtual bool canRedo(); //! Redoes last operation MODEL_EXPORT virtual void redo(); + //! Clears undo/redo lists + MODEL_EXPORT virtual void clearUndoRedo(); //! Adds to the document the new feature of the given feature id //! \param theID creates feature and puts it in the document @@ -135,7 +137,7 @@ class Model_Document : public ModelAPI_Document //! \param theName name of the object to search //! \returns null if such object is not found MODEL_EXPORT virtual std::shared_ptr objectByName( - const std::string& theGroupID, const std::string& theName); + const std::string& theGroupID, const std::wstring& theName); //! Returns the object index in the group. Object must be visible. Otherwise returns -1. //! \param theObject object of this document @@ -273,18 +275,20 @@ class Model_Document : public ModelAPI_Document void setExecuteFeatures(const bool theFlag); //! Registers the name of the shape for the topological naming needs - void addNamingName(const TDF_Label theLabel, std::string theName); + void addNamingName(const TDF_Label theLabel, std::wstring theName); //! Updates the name of some object - void changeNamingName(std::string theOldName, const std::string theNewName, + void changeNamingName(std::wstring theOldName, const std::wstring theNewName, const TDF_Label& theLabel); //! Returns the label, keeper of the name for the topological naming needs - TDF_Label findNamingName(std::string theName, ResultPtr theContext); + TDF_Label findNamingName(std::wstring theName, ResultPtr theContext); //! Returns the number of the name in the history relatively to the given object (by label). //! Start from 1 (this object). int numberOfNameInHistory(const ObjectPtr& theNameObject, const TDF_Label& theStartFrom); //! Returns the result by name of the result (names of results must be unique, used for naming //! selection by name. - ResultPtr findByName(std::string& theName, std::string& theSubShapeName, bool& theUniqueContext); + ResultPtr findByName(std::wstring& theName, + std::wstring& theSubShapeName, + bool& theUniqueContext); ///! Returns all features of the document including the hidden features which are not in ///! history. Not very fast method, for calling once, not in big cycles. @@ -323,6 +327,9 @@ class Model_Document : public ModelAPI_Document MODEL_EXPORT virtual std::shared_ptr nextFeature( std::shared_ptr theCurrent, const bool theReverse = false) const; + //! Erases the document structure. + ~Model_Document(); + protected: //! Returns (creates if needed) the general label TDF_Label generalLabel() const; @@ -450,7 +457,7 @@ class Model_Document : public ModelAPI_Document //! Optimization for finding the shape-label by topological naming names //! The name -> list of labels where this name is appeared (the last created name is last here) - std::map > myNamingNames; + std::map > myNamingNames; //! If it is true, features are not executed on update (on abort, undo, redo) bool myExecuteFeatures;