DetDataSvc.cpp
Go to the documentation of this file.
1 #define DETECTORDATASVC_DETDATASVC_CPP
2 
3 // Include files
4 #include "DetDataSvc.h"
5 #include "GaudiKernel/IAddressCreator.h"
6 #include "GaudiKernel/IConversionSvc.h"
7 #include "GaudiKernel/IOpaqueAddress.h"
8 #include "GaudiKernel/ISvcLocator.h"
9 #include "GaudiKernel/IValidity.h"
10 #include "GaudiKernel/DataObject.h"
11 #include "GaudiKernel/MsgStream.h"
12 #include "GaudiKernel/System.h"
13 using System::isEnvSet;
14 using System::getEnv;
15 
16 #define ON_DEBUG if (UNLIKELY(outputLevel() <= MSG::DEBUG))
17 #define ON_VERBOSE if (UNLIKELY(outputLevel() <= MSG::VERBOSE))
18 
19 #define DEBMSG ON_DEBUG debug()
20 #define VERMSG ON_VERBOSE verbose()
21 
22 // Instantiation of a static factory class used by clients to create
23 // instances of this service
25 
26 // Service initialization
28  // Call base class initialization
30  if( UNLIKELY(sc.isFailure()) ) return sc;
31 
32  // Set Data Loader
33  auto cnv_svc = serviceLocator()->service<IConversionSvc>(m_persistencySvcName);
34  if( UNLIKELY(!cnv_svc) ) {
35  error() << "Unable to retrieve " << m_persistencySvcName << endmsg;
36  return StatusCode::FAILURE;
37  }
38 
39  sc = setDataLoader(cnv_svc);
40  if( UNLIKELY(sc.isFailure()) ) {
41  error() << "Unable to set DataLoader" << endmsg;
42  return sc;
43  }
44 
45  // Get address creator from the DetectorPersistencySvc
46  m_addrCreator = cnv_svc;
47  if ( UNLIKELY(!m_addrCreator) ) {
48  error() << "Unable to get AddressCreator." << endmsg;
49  return StatusCode::FAILURE;
50  }
51 
52  return setupDetectorDescription();
53 }
54 
56  // Initialize the detector data transient store
57  ON_DEBUG {
58  debug() << "Storage type used is: " << m_detStorageType << endmsg;
59  debug() << "Setting DetectorDataSvc root node... " << endmsg;
60  }
61 
62  if( m_usePersistency ) {
63 
64  IOpaqueAddress* rootAddr = nullptr;
65  if( m_detDbLocation.empty() || "empty" == m_detDbLocation ) {
66 
67  // if the name of DBlocation is not given - construct it!
68  // by retrieving the value of XMLDDBROOT
69 
71  if ( isEnvSet("XMLDDDBROOT") ) {
72  m_detDbLocation = getEnv("XMLDDDBROOT");
73  m_detDbLocation += "/DDDB/lhcb.xml";
74  }
75  }
76  if( m_detDbLocation.empty() || "empty" == m_detDbLocation ) {
77  error() << "Detector data location name not set. Detector data will "
78  "not be found." << endmsg;
79  return StatusCode::FAILURE;
80  }
81  else {
82  // Create address
83  unsigned long iargs[]={0,0};
84  const std::string args[] = {m_detDbLocation, m_detDbRootName};
86  CLID_Catalog,
87  args,
88  iargs,
89  rootAddr);
90  if( sc.isSuccess() ) {
91  sc = i_setRoot( "/" + m_detDbRootName, rootAddr );
92  if( sc.isFailure() ) {
93  error() << "Unable to set detector data store root" << endmsg;
94  return sc;
95  }
96  }
97  else {
98  error() << "Unable to create address for /dd" << endmsg;
99  return sc;
100  }
101  }
102  // Writing the description file in the output log file [bugs #2854]
103  always() << "Detector description database: " << m_detDbLocation << endmsg;
104  }
105  else {
106  info() << "Detector description not requested to be loaded" << endmsg;
107  }
108 
109  return StatusCode::SUCCESS;
110 }
111 
112 // Service initialisation
114  // The DetectorDataSvc does not need to be re-initialized. If it is done
115  // all the Algorithms having references to DetectorElements will become
116  // invalid and crash the program. (Pere Mato)
117 
118  // Call base class reinitialization
119  //StatusCode sc = DataSvc::reinitialize();
120  //if( sc.isFailure() ) return sc;
121 
122  // Delete the associated event time
123  //if( 0 != m_eventTime ) delete m_eventTime;
124  //m_eventTimeDefined = false;
125 
126  //return setupDetectorDescription();
127  return StatusCode::SUCCESS;
128 }
129 
132 {
133  DEBMSG << "Finalizing" << endmsg;
134 
135  // clears the store
136  m_usePersistency = false; // avoid creation of an empty store when clearing
137  clearStore().ignore();
138 
139  // Releases the address creator
140  m_addrCreator = nullptr;
141 
142  // Releases the DataLoader
143  setDataLoader(nullptr).ignore();
144 
145  // Finalize the base class
146  return TsDataSvc::finalize();
147 }
148 
151 
152  MsgStream log(msgSvc(), name());
153 
155 
156  if( m_usePersistency ) {
157  // Create root address
158  unsigned long iargs[] = {0,0};
159  const std::string args[] = {m_detDbLocation, m_detDbRootName};
160  IOpaqueAddress* rootAddr;
162  CLID_Catalog,
163  args,
164  iargs,
165  rootAddr);
166  // Set detector data store root
167  if( sc.isSuccess() ) {
168  sc = i_setRoot( "/" + m_detDbRootName, rootAddr );
169  if( sc.isFailure() ) {
170  error() << "Unable to set detector data store root" << endmsg;
171  }
172  } else {
173  error() << "Unable to create address for /dd" << endmsg;
174  }
175  return sc;
176 
177  }
178  return StatusCode::SUCCESS;
179 
180 }
181 
183 DetDataSvc::DetDataSvc(const std::string& name,ISvcLocator* svc) :
184  base_class(name,svc) {
185  declareProperty("DetStorageType", m_detStorageType = XML_StorageType );
186  declareProperty("DetDbLocation", m_detDbLocation = "empty" );
187  declareProperty("DetDbRootName", m_detDbRootName = "dd" );
188  declareProperty("UsePersistency", m_usePersistency = false );
189  declareProperty("PersistencySvc", m_persistencySvcName = "DetectorPersistencySvc" );
190  m_rootName = "/dd";
191  m_rootCLID = CLID_Catalog;
192 }
193 
196  m_eventTime = time;
197  DEBMSG << "Event Time set to " << eventTime() << endmsg;
198 }
199 
202  return true;
203 }
204 
207  return m_eventTime;
208 }
209 
211 void DetDataSvc::handle ( const Incident& inc ) {
212  ON_DEBUG {
213  debug() << "New incident received" << endmsg;
214  debug() << "Incident source: " << inc.source() << endmsg;
215  debug() << "Incident type: " << inc.type() << endmsg;
216  }
217 }
218 
222 
223  DEBMSG << "Method updateObject starting" << endmsg;
224 
225  // Check that object to update exists
226  if ( !toUpdate ) {
227  error() << "There is no DataObject to update" << endmsg;
228  return INVALID_OBJECT;
229  }
230 
231  // Retrieve IValidity interface of object to update
232  IValidity* condition = dynamic_cast<IValidity*>( toUpdate );
233  if ( !condition ) {
234  warning()
235  << "Cannot update DataObject: DataObject does not implement IValidity"
236  << endmsg;
237  return StatusCode::SUCCESS;
238  }
239 
240  // Check that the event time has been defined
241  if ( !validEventTime() ) {
242  warning()
243  << "Cannot update DataObject: event time undefined"
244  << endmsg;
245  return StatusCode::SUCCESS;
246  }
247 
248  // No need to update if condition is valid
249  if ( condition->isValid( eventTime() ) ) {
250  DEBMSG << "DataObject is valid: no need to update" << endmsg;
251  return StatusCode::SUCCESS;
252  }
253 
254  DEBMSG << "DataObject is invalid: update it" << endmsg;
255  // TODO: before loading updated object, update HERE its parent in data store
256 
257  // Now delegate update to the conversion service by calling the base class
258  DEBMSG << "Delegate update to relevant conversion service" << endmsg;
259  StatusCode status = TsDataSvc::updateObject(toUpdate);
260  if ( !status.isSuccess() ) {
261  error() << "Could not update DataObject" << endmsg;
262  if ( status == NO_DATA_LOADER )
263  error() << "There is no data loader" << endmsg;
264  return status;
265  }
266 
267  // Now cross-check that the new condition is valid
268  condition = dynamic_cast<IValidity*>(toUpdate);
269  if ( !condition ) {
270  error() << "Updated DataObject does not implement IValidity" << endmsg;
271  return StatusCode::FAILURE;
272  }
273  if ( FSMState() == Gaudi::StateMachine::RUNNING &&
274  !condition->isValid( eventTime() ) ) {
275  error() << "Updated DataObject is not valid" << endmsg;
276  error() << "Are you sure the conversion service has updated it?" << endmsg;
277  return StatusCode::FAILURE;
278  }
279 
280  // DataObject was successfully updated
281  DEBMSG << "Method updateObject exiting successfully" << endmsg;
282  return StatusCode::SUCCESS;
283 
284 }
bool validEventTime() const override
Check if the event time has been set.
Definition: DetDataSvc.cpp:201
Definition of the MsgStream class used to transmit messages.
Definition: MsgStream.h:24
def initialize()
Definition: AnalysisTest.py:12
The ISvcLocator is the interface implemented by the Service Factory in the Application Manager to loc...
Definition: ISvcLocator.h:25
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:244
const std::string & type() const
Access to the incident type.
Definition: Incident.h:34
const Gaudi::Time & eventTime() const override
Get the event time.
Definition: DetDataSvc.cpp:206
void handle(const Incident &) override
Inform that a new incident has occured.
Definition: DetDataSvc.cpp:211
virtual StatusCode createAddress(long svc_type, const CLID &clid, const std::string *par, const unsigned long *ipar, IOpaqueAddress *&refpAddress)=0
Create a Generic address using explicit arguments to identify a single object.
const std::string & source() const
Access to the source of the incident.
Definition: Incident.h:40
bool isSuccess() const
Test for a status code of SUCCESS.
Definition: StatusCode.h:76
StatusCode updateObject(IRegistry *pDirectory) override
Update object identified by its directory entry.
Definition: TsDataSvc.cpp:1017
StatusCode updateObject(DataObject *toUpdate) override
Update object.
Definition: DetDataSvc.cpp:221
StatusCode initialize() override
Service initialization.
Definition: TsDataSvc.cpp:1321
const long XML_StorageType
Definition: ClassID.h:57
std::string m_persistencySvcName
Name of the persistency service.
Definition: DetDataSvc.h:96
#define ON_DEBUG
Definition: DetDataSvc.cpp:16
bool isFailure() const
Test for a status code of FAILURE.
Definition: StatusCode.h:86
StatusCode setupDetectorDescription()
Deal with Detector Description initialization.
Definition: DetDataSvc.cpp:55
StatusCode clearStore() override
Remove all data objects in the data store.
Definition: DetDataSvc.cpp:150
Based on seal::Time.
Definition: Time.h:213
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:26
#define DECLARE_COMPONENT(type)
Definition: PluginService.h:36
SmartIF< IAddressCreator > m_addrCreator
Address Creator to be used.
Definition: DetDataSvc.h:105
GAUDI_API bool isEnvSet(const char *var)
Check if an environment variable is set or not.
Definition: System.cpp:637
int m_detStorageType
Detector Data Persistency Storage type.
Definition: DetDataSvc.h:87
DetDataSvc(const std::string &name, ISvcLocator *svc)
Standard Constructor.
Definition: DetDataSvc.cpp:183
StatusCode reinitialize() override
Initialize the service.
Definition: DetDataSvc.cpp:113
GAUDI_API std::string getEnv(const char *var)
get a particular environment variable (returning "UNKNOWN" if not set)
Definition: System.cpp:617
virtual bool isValid() const =0
Check if the object is valid (it can be always invalid).
StatusCode finalize() override
Finalize the service.
Definition: DetDataSvc.cpp:131
#define DEBMSG
Definition: DetDataSvc.cpp:19
std::string m_detDbRootName
Name of the root node of the detector.
Definition: DetDataSvc.h:93
StatusCode finalize() override
Service initialization.
Definition: TsDataSvc.cpp:1362
list args
Definition: gaudirun.py:290
Gaudi::Time m_eventTime
Current event time.
Definition: DetDataSvc.h:102
Base class used to extend a class implementing other interfaces.
Definition: extends.h:10
std::string m_detDbLocation
Location of detector Db (filename,URL)
Definition: DetDataSvc.h:90
Base class for all Incidents (computing events).
Definition: Incident.h:16
#define UNLIKELY(x)
Definition: Kernel.h:126
void setEventTime(const Gaudi::Time &time) override
Set the new event time.
Definition: DetDataSvc.cpp:195
Interface for objects with a validity.
Definition: IValidity.h:9
StatusCode clearStore() override
IDataManagerSvc: Remove all data objects in the data store.
Definition: TsDataSvc.cpp:115
Opaque address interface definition.
void ignore() const
Definition: StatusCode.h:108
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
bool m_usePersistency
Flag to control if the persistency is required.
Definition: DetDataSvc.h:99