ATLAS Offline Software
Loading...
Searching...
No Matches
DbDatabase.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4
5//====================================================================
6// DbDatabase and related class definitions
7//--------------------------------------------------------------------
8//
9// Package : StorageSvc (The POOL project)
10// @author M.Frank
11//====================================================================
12#ifndef POOL_DBDATABASE_H
13#define POOL_DBDATABASE_H
14
15// Framework include files
18#include "StorageSvc/pool.h"
20
21// STL include files
22#include <vector>
23#include <string>
24#include <map>
25
26class StatusCode;
27
28/*
29 * POOL namespace declaration
30 */
31namespace pool {
32
33 // Forward declarations
34 class IOODatabase;
35 class IDbDatabase;
36 class IDbContainer;
37 class DbDomain;
38 class DbDatabase;
39 class DbDatabaseObj;
40 class DbContainer;
41 class DbContainerObj;
42 class DbOption;
43 class DbTypeInfo;
44 typedef const class Shape *ShapeH;
45
54 class DbDatabase : public DbHandleBase<DbDatabaseObj> {
55 protected:
57 typedef std::pair<std::string, std::string> Parameter;
59 typedef std::vector< Parameter > Parameters;
60
63 public:
65 explicit DbDatabase(const DbType& typ=POOL_StorageType) { m_type = typ; }
67 DbDatabase(const DbDatabase& cp) : Base() { switchPtr(cp.m_ptr); }
71 virtual ~DbDatabase() { switchPtr(0); }
74 if ( &copy != this ) {
75 m_type = copy.m_type;
76 switchPtr( copy.m_ptr );
77 }
78 return *this;
79 }
80
81 DbDatabase& operator=(const int /* nuller */ ) {
82 switchPtr(0);
83 return *this;
84 }
85
86 // Move
88 {
89 setPtr (cp.m_ptr);
90 setType (cp.m_type);
91 cp.setPtr (nullptr);
92 cp.setType(DbType(0));
93 }
95 {
96 if (&cp != this) {
97 switchPtr (nullptr);
98 setPtr (cp.m_ptr);
99 setType (cp.m_type);
100 cp.setPtr (nullptr);
101 cp.setType(DbType(0));
102 }
103 return *this;
104 }
105
107 int refCount() const;
111 const std::string& name() const;
113 void setName(const std::string& nam);
115 const std::string& logon() const;
117 long long int size();
120 const IOODatabase* db() const;
122 StatusCode add(const std::string& name, DbContainerObj* cnt);
124 StatusCode remove(const DbContainerObj* cnt);
126 const DbContainerObj* find(const std::string& nam) const;
128 DbContainerObj* find(const std::string& nam);
130 const Token* token() const;
132 const DbDomain& containedIn() const;
135 bool exist(DbDomain& domH, const std::string& nam) const;
137
143 StatusCode open(DbDomain& domH,
144 const std::string& pfn,
145 const std::string& fid,
146 DbAccessMode mode = pool::READ);
148 StatusCode close();
150 StatusCode retire();
152 bool isOpen() const;
154
157 StatusCode transAct(Transaction::Action action);
159
162 StatusCode setOption(const DbOption& refOpt);
164
167 StatusCode getOption(DbOption& refOpt);
169 StatusCode addParam(const std::string& nam, const std::string& val);
171 int nParam();
173 StatusCode param(const std::string& nam, std::string& val);
175 StatusCode params(Parameters& vals);
176
178 StatusCode read(const Token& token, ShapeH shape, void** object);
180 StatusCode getLink(const Token::OID_t& oid, Token* pTok);
182 std::string cntName(Token& token);
184 StatusCode makeLink(Token* pToken, Token::OID_t& linkH);
186 StatusCode addShape(const DbTypeInfo* pShape);
188 const DbTypeInfo* objectShape(const RootType& typeH);
190 const DbTypeInfo* objectShape(const Guid& nam);
192 const DbTypeInfo* contShape(const std::string& nam);
194 const Token* cntToken(const std::string& cntName);
196 StatusCode containers(std::vector<const Token*>& conts, bool intern=false);
197 StatusCode containers(std::vector<IDbContainer*>& conts, bool intern=false);
199 StatusCode shapes(std::vector<const DbTypeInfo*>& shaps);
202 const IDbDatabase* info() const;
204 void setAge(int value);
206 int age() const;
207 };
208} // End namespace pool
209#endif // POOL_DBDatabase_H
TTypeAdapter RootType
Definition RootType.h:211
This file contains the class definition for the Token class (migrated from POOL).
This class provides a token that identifies in a unique way objects on the persistent storage.
Definition Token.h:21
Description: Definition of the object describing a database container Handle managing a DbContainerOb...
Definition DbContainer.h:48
Description: Handle managing a DbDatabaseObj, a generic Database object.
Definition DbDatabase.h:54
void switchPtr(DbDatabaseObj *obj)
Assign transient object properly (including reference counting)
StatusCode add(const std::string &name, DbContainerObj *cnt)
Add domain to session.
StatusCode param(const std::string &nam, std::string &val)
Retrieve existing parameter by name.
const DbContainerObj * find(const std::string &nam) const
Select container object in Database.
StatusCode remove(const DbContainerObj *cnt)
Find domain in session.
void setName(const std::string &nam)
Set db name (FID) after opening in case opening happened by PFN.
StatusCode close()
Close Database.
int age() const
Access age value.
DbDatabase(const DbType &typ=POOL_StorageType)
Constructor with initializing arguments.
Definition DbDatabase.h:65
DbDatabase(DbDatabase &&cp)
Definition DbDatabase.h:87
IDbDatabase * info()
Let the implementation access the internals.
IOODatabase * db()
Allow access to the Database implementation.
const DbTypeInfo * objectShape(const Guid &nam)
Retrieve persistent type information by name.
StatusCode makeLink(Token *pToken, Token::OID_t &linkH)
Add association link to link container.
StatusCode read(const Token &token, ShapeH shape, void **object)
read an object referenced by the token
StatusCode shapes(std::vector< const DbTypeInfo * > &shaps)
Allow access to all known shapes used by the database.
StatusCode getOption(DbOption &refOpt)
Access options.
void setAge(int value)
Update database age.
DbDomain & containedIn()
std::string cntName(Token &token)
Retrieve container name from link container (using token oid, rather than contID)
StatusCode addShape(const DbTypeInfo *pShape)
Add persistent shape to the Database.
const std::string & name() const
Access to db name (FID)
bool exist(DbDomain &domH, const std::string &nam) const
Check for existence of Database within domain.
DbAccessMode openMode() const
Access to access mode member.
DbDatabase & operator=(const DbDatabase &copy)
Assignment (copy) operator.
Definition DbDatabase.h:73
const IDbDatabase * info() const
bool isOpen() const
Check if the database was opened.
StatusCode addParam(const std::string &nam, const std::string &val)
Add a persistent parameter to the file.
const Token * cntToken(const std::string &cntName)
Access local container token (if container exists)
long long int size()
Access the size of the database: May be undefined for some technologies.
StatusCode params(Parameters &vals)
Retrieve all parameters.
StatusCode open(DbDomain &domH, const std::string &pfn, const std::string &fid, DbAccessMode mode=pool::READ)
Open Database using given domain.
StatusCode transAct(Transaction::Action action)
Commit Database Transaction.
std::pair< std::string, std::string > Parameter
Parameter definition.
Definition DbDatabase.h:57
const DbDomain & containedIn() const
Access to domain object.
int refCount() const
Access reference counter.
const Token * token() const
Access the token of the database object.
DbDatabase(DbDatabaseObj *obj)
Constructor.
Definition DbDatabase.h:69
int nParam()
Retrieve the number of user parameters.
DbContainerObj * find(const std::string &nam)
Select container object in Database.
DbDatabase(const DbDatabase &cp)
Copy constructor.
Definition DbDatabase.h:67
const DbTypeInfo * objectShape(const RootType &typeH)
Retrieve persistent type information by class handle.
StatusCode containers(std::vector< const Token * > &conts, bool intern=false)
Allow access to all known containers.
StatusCode containers(std::vector< IDbContainer * > &conts, bool intern=false)
const std::string & logon() const
Access to db logon string.
StatusCode retire()
End database access, but still leave database accessible.
const DbTypeInfo * contShape(const std::string &nam)
Retrieve persistent type information by container.
std::vector< Parameter > Parameters
Parameter container definition.
Definition DbDatabase.h:59
StatusCode setOption(const DbOption &refOpt)
Set options.
const IOODatabase * db() const
StatusCode getLink(const Token::OID_t &oid, Token *pTok)
Expand OID into a full Token, based on the Links table.
virtual ~DbDatabase()
Standard destructor.
Definition DbDatabase.h:71
DbDatabase & operator=(const int)
Assignment operator to reset handle using 0.
Definition DbDatabase.h:81
Description:
Definition DbDomain.h:47
void setPtr(DbDatabaseObj *ptr)
void setType(const DbType &typ)
DbHandleBase< _DataType > Base
Description: Definition an option to be supplied to database objects.
Definition DbOption.h:36
Definition of class DbTypeInfo.
Definition DbTypeInfo.h:49
IDbDatabase interface.
Definition IDbDatabase.h:41
Description:
Definition Shape.h:35
Framework include files.
Definition libname.h:15
const class Shape * ShapeH
static const DbType POOL_StorageType
Definition DbType.h:84