X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_Application.h;h=3d905dc41e35994026e0f9def396184112a65f7b;hb=50c050906e6b5926727fcbadcbf4247326ef60be;hp=c4f578f0443e755afdbd314578199f3d91457f94;hpb=3a272fa1aff115d8ff8744d54a09bc7f2d5576b4;p=modules%2Fshaper.git diff --git a/src/Model/Model_Application.h b/src/Model/Model_Application.h index c4f578f04..3d905dc41 100644 --- a/src/Model/Model_Application.h +++ b/src/Model/Model_Application.h @@ -3,8 +3,8 @@ // Author: Mikhail PONIKAROV // Copyright: CEA 2011 -#ifndef Model_Application_HeaderFile -#define Model_Application_HeaderFile +#ifndef Model_Application_H_ +#define Model_Application_H_ #include #include @@ -19,22 +19,34 @@ DEFINE_STANDARD_HANDLE(Model_Application, TDocStd_Application) * Application supports the formats and document management. It is uses OCAF-lke * architecture and just implements specific features of the module. */ -class Model_Application: public TDocStd_Application +class Model_Application : public TDocStd_Application { -public: + public: // useful methods inside of the module // CASCADE RTTI - DEFINE_STANDARD_RTTI(Model_Application); + DEFINE_STANDARD_RTTI(Model_Application) + ; //! Retuns the application: one per process MODEL_EXPORT static Handle_Model_Application getApplication(); //! Returns the main document (on first call creates it) by the string identifier MODEL_EXPORT const std::shared_ptr& getDocument(std::string theDocID); + //! Returns true if document has been created + MODEL_EXPORT bool hasDocument(std::string theDocID); //! Deletes the document from the application MODEL_EXPORT void deleteDocument(std::string theDocID); + //! Deletes all documents existing in the application + MODEL_EXPORT void deleteAllDocuments(); -public: + //! Set path for the loaded by demand documents + void setLoadPath(std::string thePath); + //! Defines that specified document must be loaded by demand + void setLoadByDemand(std::string theID); + //! Returns true if specified document must be loaded by demand + bool isLoadByDemand(std::string theID); + + public: // Redefined OCAF methods //! Return name of resource (i.e. "Standard") Standard_CString ResourcesName(); @@ -46,9 +58,13 @@ public: //! the static instance of the object (or derive your own application) Model_Application(); -private: + private: /// Map from string identifiers to created documents of an application std::map > myDocs; + /// Path for the loaded by demand documents + std::string myPath; + /// Path for the loaded by demand documents + std::set myLoadedByDemand; }; #endif