1 // File: SalomeApp_DataModel.h
2 // Created: 10/25/2004 10:32:33 AM
3 // Author: Sergey LITONIN
4 // Copyright (C) CEA 2004
6 #ifndef SALOMEAPP_DATAMODEL_H
7 #define SALOMEAPP_DATAMODEL_H
11 #endif // _MSC_VER > 1000
13 #include "SalomeApp.h"
14 #include "CAM_DataModel.h"
16 #include "SALOMEDSClient.hxx"
19 Class : SalomeApp_DataModel
20 Description : Base class of data model
23 class SalomeApp_Module;
24 class SalomeApp_Study;
25 class SalomeApp_DataObject;
26 class SalomeApp_SelectionMgr;
28 class SALOMEAPP_EXPORT SalomeApp_DataModel : public CAM_DataModel
33 static SUIT_DataObject* BuildTree(const _PTR(SObject)& obj,
34 SUIT_DataObject* parent,
35 SalomeApp_Study* study );
37 SalomeApp_DataModel ( CAM_Module* theModule );
38 virtual ~SalomeApp_DataModel();
40 // These methods should be redefined in successors.
41 virtual bool open( const QString&, CAM_Study* );
43 virtual bool saveAs( const QString&, CAM_Study* );
46 virtual void update( SalomeApp_DataObject* = 0, SalomeApp_Study* = 0 );
48 virtual bool isModified() const;
49 virtual bool isSaved() const;
57 SalomeApp_Module* getModule() const;
58 SalomeApp_Study* getStudy() const;
60 virtual void buildTree(const _PTR(SObject)&, SUIT_DataObject*, SalomeApp_Study* );
62 // BEGIN: methods to be used by CORBAless modules
63 std::vector<std::string> GetListOfFiles () const;
64 void SetListOfFiles (const std::vector<std::string> theListOfFiles);
66 static std::string GetTmpDir (const char* theURL,
67 const bool isMultiFile);
69 void RemoveTemporaryFiles (const bool isMultiFile) const;
70 // END: methods to be used by CORBAless modules
73 QString getRootEntry( SalomeApp_Study* ) const;