X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Session.h;h=5c927e7d3eec56226d1b56c43e9e9cbe23acf550;hb=a3ee4e38876c359fdf737179605db194bca4ecbb;hp=d3937841615e61dedc5920683498d6a40233a86d;hpb=bc91dea057824b77d28e26cb9cacb40f0c320dde;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Session.h b/src/ModelAPI/ModelAPI_Session.h index d39378416..5c927e7d3 100644 --- a/src/ModelAPI/ModelAPI_Session.h +++ b/src/ModelAPI/ModelAPI_Session.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_Session.hxx // Created: 20 Mar 2014 // Author: Mikhail PONIKAROV @@ -8,7 +10,7 @@ #include "ModelAPI.h" #include #include -#include +#include class ModelAPI_Feature; class ModelAPI_Plugin; @@ -26,11 +28,10 @@ class MODELAPI_EXPORT ModelAPI_Session { public: /// Returns the real implementation (the alone instance per application) of the plugin manager - static boost::shared_ptr get(); + static std::shared_ptr get(); //! Loads the OCAF document from the file. //! \param theFileName full name of the file to load - //! \param theStudyID identifier of the SALOME study to associate with loaded file //! \returns true if file was loaded successfully virtual bool load(const char* theFileName) = 0; @@ -40,8 +41,12 @@ class MODELAPI_EXPORT ModelAPI_Session //! \returns true if file was stored successfully virtual bool save(const char* theFileName, std::list& theResults) = 0; + //! Closes all documents + virtual void closeAll() = 0; + //! Starts a new operation (opens a tansaction) - virtual void startOperation() = 0; + //! \param theId of operation for history (optional) + virtual void startOperation(const std::string& theId = "") = 0; //! Finishes the previously started operation (closes the transaction) virtual void finishOperation() = 0; //! Aborts the operation @@ -59,6 +64,10 @@ class MODELAPI_EXPORT ModelAPI_Session virtual bool canRedo() = 0; //! Redoes last operation virtual void redo() = 0; + //! Returns stack of performed operations (from last to first) + virtual std::list undoList() = 0; + //! Returns stack of rolled back operations (from last rolled back to first) + virtual std::list redoList() = 0; /// Registers the plugin that creates features. /// It is obligatory for each plugin to call this function on loading to be found by @@ -66,22 +75,26 @@ class MODELAPI_EXPORT ModelAPI_Session virtual void registerPlugin(ModelAPI_Plugin* thePlugin) = 0; /// Returns the root document of the application (that may contains sub-documents) - virtual boost::shared_ptr moduleDocument() = 0; + virtual std::shared_ptr moduleDocument() = 0; + + /// Returns the document by ID, loads if not loaded yet. Returns null if no such document. + virtual std::shared_ptr document(std::string theDocID) = 0; /// Return true if root document has been already created virtual bool hasModuleDocument() = 0; /// Returns the current document that used for current work in the application - virtual boost::shared_ptr activeDocument() = 0; + virtual std::shared_ptr activeDocument() = 0; /// Defines the current document that used for current work in the application - virtual void setActiveDocument(boost::shared_ptr theDoc) = 0; + virtual void setActiveDocument( + std::shared_ptr theDoc, bool theSendSignal = true) = 0; /// Returns all the opened documents of the session (without postponed) - virtual std::list > allOpenedDocuments() = 0; + virtual std::list > allOpenedDocuments() = 0; /// Copies the document to the new one with the given id - virtual boost::shared_ptr copy(boost::shared_ptr theSource, + virtual std::shared_ptr copy(std::shared_ptr theSource, std::string theID) = 0; /// Returns the validators factory: the only one instance per application @@ -93,14 +106,10 @@ class MODELAPI_EXPORT ModelAPI_Session } protected: - /// Creates the feature object using plugins functionality - virtual boost::shared_ptr createFeature(std::string theFeatureID) = 0; - - static void setSession(boost::shared_ptr theManager); - - friend class Model_Document; + /// Sets the session interface implementation (once per application launch) + static void setSession(std::shared_ptr theManager); }; -typedef boost::shared_ptr SessionPtr; +typedef std::shared_ptr SessionPtr; #endif