ATLAS Offline Software
PoolCollectionConverter.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 
11 #include "PoolSvc/IPoolSvc.h"
13 
14 // Pool
15 #include "CoralBase/AttributeList.h"
16 #include "CoralBase/Attribute.h"
17 
23 
24 // Gaudi
25 #include "GaudiKernel/StatusCode.h"
26 
27 #include <assert.h>
28 #include <exception>
29 
30 //______________________________________________________________________________
31 PoolCollectionConverter::PoolCollectionConverter(const std::string& collectionType,
32  const std::string& inputCollection,
33  unsigned int contextId,
34  const std::string& query,
35  const IPoolSvc* svc) :
36  m_collectionType(),
37  m_connection(),
38  m_inputCollection(inputCollection),
39  m_contextId(contextId),
40  m_query(query),
41  m_poolSvc(svc),
42  m_poolCollection(nullptr),
43  m_collectionQuery(nullptr),
44  m_inputContainer() {
45  // Find out if the user specified a container
46  std::string::size_type p_colon = collectionType.rfind(':');
47  if (p_colon != std::string::npos) {
48  m_inputContainer = collectionType.substr(p_colon + 1);
49  m_collectionType = collectionType.substr(0, p_colon);
50  } else {
51  // The user didn't specify any container. Using the default one.
52  m_inputContainer = "POOLContainer";
53  m_collectionType = collectionType;
54  }
55  std::string::size_type p_slash = m_inputContainer.find('/');
56  if (p_slash != std::string::npos) {
57  m_inputContainer.resize(p_slash);
58  }
59 }
60 //______________________________________________________________________________
62  if (m_poolCollection) {
64  delete m_collectionQuery; m_collectionQuery = nullptr;
65  delete m_poolCollection; m_poolCollection = nullptr;
66  }
67 }
68 //______________________________________________________________________________
70  std::string collectionTypeString;
71  if (m_collectionType == "ExplicitROOT") {
72  collectionTypeString = "RootCollection";
73  } else if (m_collectionType == "ImplicitROOT") {
74  collectionTypeString = "ImplicitCollection";
75  } else {
76  return(StatusCode::FAILURE);
77  }
78  if (collectionTypeString == "ImplicitCollection") {
79  // Check if already prefixed
80  if (m_inputCollection.starts_with( "PFN:")
81  || m_inputCollection.starts_with( "LFN:")
82  || m_inputCollection.starts_with( "FID:")) {
83  // Aready prefixed
85  } else {
86  // Prefix with PFN:
88  }
89  try {
91  } catch (std::exception &e) {
92  m_poolCollection = nullptr;
93  }
94  if (m_poolCollection == nullptr) {
95  // Now set where to look in the implicit file
96  m_inputCollection = m_inputContainer + "(DataHeader)";
97  }
98  }
99  try {
100  if (m_poolCollection == nullptr) {
102  }
103  if (m_poolCollection == nullptr && collectionTypeString == "ImplicitCollection") {
104  m_inputCollection = m_inputContainer + "_DataHeader";
106  }
107  } catch (std::exception &e) {
108  return(StatusCode::RECOVERABLE);
109  }
110  return(StatusCode::SUCCESS);
111 }
112 //______________________________________________________________________________
114  if (m_poolCollection == nullptr) {
115  return(StatusCode::SUCCESS);
116  }
117  if (m_poolCollection->description().type() == "ImplicitCollection") {
119  }
120  return(StatusCode::SUCCESS);
121 }
122 //______________________________________________________________________________
124  return(m_poolCollection != nullptr ? StatusCode::SUCCESS : StatusCode::FAILURE);
125 }
126 //______________________________________________________________________________
128  assert(m_poolCollection);
129  delete m_collectionQuery; m_collectionQuery = nullptr;
131  m_collectionQuery->setRowCacheSize(100); //MN: FIXME - just an arbitrary number
132  return(m_collectionQuery->execute());
133 }
134 //______________________________________________________________________________
136  assert(m_poolCollection);
137  delete m_collectionQuery; m_collectionQuery = nullptr;
141  m_collectionQuery->setRowCacheSize(100); //MN: FIXME - just an arbitrary number
142  return(m_collectionQuery->execute());
143 }
144 //______________________________________________________________________________
146  const std::string& refName) const {
147 // Retrieve the DataHeader Token from POOL.
148 // If header name is non-zero, then search the attibute list for
149 // the corresponding ref. Otherwise, use the main token
150  std::string tokenStr;
151  if (!refName.empty()) {
152  std::string attrName = refName + "_ref";
153  try {
154  tokenStr = cursor->currentRow().tokenList()[attrName].toString();
155  } catch (...) {
156  // check also in attributes, for backward compatibility
157  try {
158  tokenStr = cursor->currentRow().attributeList()[attrName].data<std::string>();
159  } catch (std::exception& e) {
160  return("");
161  }
162  }
163  } else {
164  tokenStr = cursor->eventRef().toString();
165  }
166  return(tokenStr);
167 }
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
IPoolSvc
This class provides the interface to the LCG POOL persistency software.
Definition: IPoolSvc.h:35
PoolCollectionConverter::m_contextId
unsigned int m_contextId
Definition: PoolCollectionConverter.h:70
PoolCollectionConverter::PoolCollectionConverter
PoolCollectionConverter(const std::string &collectionType, const std::string &inputCollection, unsigned int contextId, const std::string &query, const IPoolSvc *svc)
Constructor.
Definition: PoolCollectionConverter.cxx:31
PoolCollectionConverter::m_connection
std::string m_connection
Definition: PoolCollectionConverter.h:68
PoolCollectionConverter::executeQuery
pool::ICollectionCursor & executeQuery()
Query the collection.
Definition: PoolCollectionConverter.cxx:135
PoolCollectionConverter.h
This file contains the class definition for the PoolCollectionConverter class.
ICollectionCursor.h
pool::ICollectionQuery::execute
virtual pool::ICollectionCursor & execute()=0
Processes the query and returns a cursor over the query result.
PoolCollectionConverter::selectAll
pool::ICollectionCursor & selectAll()
Definition: PoolCollectionConverter.cxx:127
pool::ICollection::close
virtual void close()=0
Closes the collection and terminates any database connections.
PoolCollectionConverter::m_collectionType
std::string m_collectionType
Definition: PoolCollectionConverter.h:67
pool::ICollectionDescription::type
virtual const std::string & type() const =0
Returns the storage technology type of the collection.
pool::ICollectionQuery::selectAll
virtual void selectAll()=0
Adds all Token and Attribute columns to the query select list.
PoolCollectionConverter::m_inputCollection
std::string m_inputCollection
Definition: PoolCollectionConverter.h:69
PoolCollectionConverter::m_inputContainer
std::string m_inputContainer
Definition: PoolCollectionConverter.h:75
pool::ICollection::newQuery
virtual ICollectionQuery * newQuery()=0
Returns an object used to query the collection.
PoolCollectionConverter::isValid
StatusCode isValid() const
Check whether has valid pool::ICollection*.
Definition: PoolCollectionConverter.cxx:123
query
Definition: query.py:1
CollectionRowBuffer.h
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
PoolCollectionConverter::m_poolSvc
const IPoolSvc * m_poolSvc
Definition: PoolCollectionConverter.h:72
calibdata.exception
exception
Definition: calibdata.py:496
ICollection.h
pool::ICollection::description
virtual const ICollectionDescription & description() const =0
Returns an object used to describe the collection properties.
Handler::svc
AthROOTErrorHandlerSvc * svc
Definition: AthROOTErrorHandlerSvc.cxx:10
pool::ICollectionCursor
Definition: ICollectionCursor.h:21
PoolCollectionConverter::retrieveToken
std::string retrieveToken(const pool::ICollectionCursor *cursor, const std::string &refName) const
Definition: PoolCollectionConverter.cxx:145
PoolCollectionConverter::m_query
std::string m_query
Definition: PoolCollectionConverter.h:71
PoolCollectionConverter::m_collectionQuery
pool::ICollectionQuery * m_collectionQuery
Definition: PoolCollectionConverter.h:74
IPoolSvc.h
This file contains the class definition for the IPoolSvc interface class.
pool::ICollectionQuery::setCondition
virtual void setCondition(const std::string &whereClause, coral::AttributeList *attributeBindData=0, TokenList *tokenBindData=0)=0
Sets the predicates of the query.
PoolCollectionConverter::disconnectDb
StatusCode disconnectDb()
Disconnect Database.
Definition: PoolCollectionConverter.cxx:113
PoolCollectionConverter::initialize
StatusCode initialize()
Required by all Gaudi Services.
Definition: PoolCollectionConverter.cxx:69
PoolCollectionConverter::m_poolCollection
pool::ICollection * m_poolCollection
Definition: PoolCollectionConverter.h:73
python.PoolAttributeHelper.attrName
attrName
Definition: PoolAttributeHelper.py:100
query_example.cursor
cursor
Definition: query_example.py:21
IPoolSvc::disconnectDb
virtual StatusCode disconnectDb(const std::string &connection, unsigned int contextId=IPoolSvc::kInputStream) const =0
Disconnect single Database.
ICollectionQuery.h
pool::ICollectionQuery::setRowCacheSize
virtual void setRowCacheSize(int rowCacheSize)=0
Sets the cache size used to store the query result.
PoolCollectionConverter::~PoolCollectionConverter
virtual ~PoolCollectionConverter()
Destructor.
Definition: PoolCollectionConverter.cxx:61
ICollectionDescription.h
Token.h
This file contains the class definition for the Token class (migrated from POOL).
IPoolSvc::createCollection
virtual pool::ICollection * createCollection(const std::string &collectionType, const std::string &connection, const std::string &collectionName, unsigned int contextId=IPoolSvc::kInputStream) const =0