Loading [MathJax]/extensions/tex2jax.js
The Gaudi Framework  v31r0 (aeb156f0)
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
RConverter.h
Go to the documentation of this file.
1 #ifndef ROOTHISTCNV_RCONVERTER_H
2 #define ROOTHISTCNV_RCONVERTER_H 1
3 
4 // Include files
6 #include "TDirectory.h"
7 #include <map>
8 #include <string>
9 
10 // Forward declarations
11 class ISvcLocator;
12 class TObject;
13 class TTree;
14 class TFile;
15 
17  TDirectory* m_current;
18 
19 public:
20  GlobalDirectoryRestore() { m_current = gDirectory; }
21  virtual ~GlobalDirectoryRestore() { gDirectory = m_current; }
22 };
23 
24 namespace RootHistCnv {
25 
31  class RConverter : public Converter {
32  public:
34  StatusCode createRep( DataObject* pObj, IOpaqueAddress*& refpAddr ) override;
36  static long storageType() { return ROOT_StorageType; }
37  long repSvcType() const override { return i_repSvcType(); }
38 
39  StatusCode error( const std::string& msg );
40  StatusCode regTFile( const std::string, const TFile* );
41  StatusCode findTFile( const std::string, TFile*& );
42 
43  std::string diskDirectory( const std::string& loc );
44  std::string directory( const std::string& loc );
45  void setDirectory( const std::string& loc );
46  void setDiskDirectory( const std::string& loc );
47  StatusCode createDirectory( const std::string& loc );
48  StatusCode createDiskDirectory( const std::string& loc );
49  std::string getDirectory();
50 
51  std::string convertId( const std::string& ) const;
52 
53  protected:
55  RConverter( const CLID& clid, ISvcLocator* svc ) : Converter( storageType(), clid, svc ) {}
57  virtual StatusCode readObject( IOpaqueAddress* pAddr, DataObject*& refpObj );
59  virtual TObject* createPersistent( DataObject* pObj );
61  StatusCode createAddress( DataObject* pObject, TDirectory* pDir, TObject* pTObject, IOpaqueAddress*& refpAddr );
62 
63  StatusCode createAddress( const std::string& rzdir, const CLID& clid, long id, TObject* pTobj,
64  IOpaqueAddress*& refpAddress );
65 
66  StatusCode createAddress( const std::string& rzdir, const CLID& clid, const std::string& title, TObject* pTobj,
67  IOpaqueAddress*& refpAddress );
68 
70  TDirectory* changeDirectory( DataObject* pObject );
71  };
72 } // namespace RootHistCnv
73 
74 #endif // RootHistCnv_RConverter_H
Root Converter.
Definition: RConverter.h:31
RConverter(const CLID &clid, ISvcLocator *svc)
Standard constructor.
Definition: RConverter.h:55
The ISvcLocator is the interface implemented by the Service Factory in the Application Manager to loc...
Definition: ISvcLocator.h:25
static long storageType()
Inquire storage type.
Definition: RConverter.h:36
STL class.
long repSvcType() const override
Definition: RConverter.h:37
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:50
const long ROOT_StorageType
Definition: ClassID.h:52
TDirectory * m_current
Definition: RConverter.h:17
virtual ~GlobalDirectoryRestore()
Definition: RConverter.h:21
unsigned int CLID
Class ID definition.
Definition: ClassID.h:8
Converter base class.
Definition: Converter.h:24
Opaque address interface definition.
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30