The Gaudi Framework  v32r2 (46d42edc)
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 
44  std::string directory( const std::string& loc );
45  void setDirectory( const std::string& loc );
46  void setDiskDirectory( const std::string& loc );
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
std::string getDirectory()
Definition: RConverter.cpp:148
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
std::string diskDirectory(const std::string &loc)
Definition: RConverter.cpp:69
void setDirectory(const std::string &loc)
Definition: RConverter.cpp:108
virtual long i_repSvcType() const
Retrieve the class type of the data store the converter uses.
Definition: Converter.cpp:16
StatusCode createDiskDirectory(const std::string &loc)
StatusCode createRep(DataObject *pObj, IOpaqueAddress *&refpAddr) override
Convert the transient object to the requested representation.
Definition: RConverter.cpp:228
StatusCode regTFile(const std::string, const TFile *)
Definition: RConverter.cpp:264
StatusCode findTFile(const std::string, TFile *&)
Definition: RConverter.cpp:279
StatusCode createDirectory(const std::string &loc)
Definition: RConverter.cpp:24
TDirectory * changeDirectory(DataObject *pObject)
Switch to object directory (=Parent directory)
Definition: RConverter.cpp:200
static long storageType()
Inquire storage type.
Definition: RConverter.h:36
STL class.
virtual TObject * createPersistent(DataObject *pObj)
Create the persistent representation of an object.
Definition: RConverter.cpp:261
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
std::string directory(const std::string &loc)
Definition: RConverter.cpp:101
StatusCode error(const std::string &msg)
Definition: RConverter.cpp:329
long repSvcType() const override
Definition: RConverter.h:37
std::string convertId(const std::string &) const
Definition: RConverter.cpp:312
virtual StatusCode readObject(IOpaqueAddress *pAddr, DataObject *&refpObj)
Create the transient representation of an object.
Definition: RConverter.cpp:250
Opaque address interface definition.
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
StatusCode createAddress(DataObject *pObject, TDirectory *pDir, TObject *pTObject, IOpaqueAddress *&refpAddr)
Create address of the transient object according to the requested representation.
Definition: RConverter.cpp:155
void setDiskDirectory(const std::string &loc)
Definition: RConverter.cpp:141