The Gaudi Framework  master (37c0b60a)
ReadTES.cpp
Go to the documentation of this file.
1 /***********************************************************************************\
2 * (c) Copyright 1998-2019 CERN for the benefit of the LHCb and ATLAS collaborations *
3 * *
4 * This software is distributed under the terms of the Apache version 2 licence, *
5 * copied verbatim in the file "LICENSE". *
6 * *
7 * In applying this licence, CERN does not waive the privileges and immunities *
8 * granted to it by virtue of its status as an Intergovernmental Organization *
9 * or submit itself to any jurisdiction. *
10 \***********************************************************************************/
11 // Include files
12 
13 // local
14 #include "ReadTES.h"
15 
16 //-----------------------------------------------------------------------------
17 // Implementation file for class : ReadTES
18 //
19 // 2008-11-03 : Marco Cattaneo
20 //-----------------------------------------------------------------------------
21 
22 // Declaration of the Algorithm Factory
24 
25 //=============================================================================
26 // Initialization
27 //=============================================================================
28 StatusCode ReadTES::initialize() {
29  StatusCode sc = Algorithm::initialize(); // must be executed first
30  if ( sc.isFailure() ) return sc; // error printed already by Algorithm
31 
32  if ( msgLevel( MSG::DEBUG ) ) debug() << "==> Initialize" << endmsg;
33 
34  if ( m_locations.empty() ) {
35  error() << "You must define at least one TES Location" << endmsg;
36  return StatusCode::FAILURE;
37  }
38 
39  return StatusCode::SUCCESS;
40 }
41 //=============================================================================
42 // Main execution
43 //=============================================================================
45 
46  if ( msgLevel( MSG::DEBUG ) ) debug() << "==> Execute" << endmsg;
47 
48  for ( auto& loc : m_locations ) {
49  DataObject* pTES = nullptr;
50  eventSvc()->retrieveObject( loc, pTES ).ignore();
51  info() << "Found object " << loc << " at " << pTES << endmsg;
52  }
53 
54  return StatusCode::SUCCESS;
55 }
56 
57 //=============================================================================
ReadTES::m_locations
Gaudi::Property< std::vector< std::string > > m_locations
Definition: ReadTES.h:38
MSG::DEBUG
@ DEBUG
Definition: IMessageSvc.h:25
Gaudi::Algorithm::eventSvc
SmartIF< IDataProviderSvc > & eventSvc() const
The standard event data service.
Definition: Algorithm.cpp:559
Gaudi::Algorithm::initialize
StatusCode initialize() override
the default (empty) implementation of IStateful::initialize() method
Definition: Algorithm.h:178
ReadTES::execute
StatusCode execute() override
Algorithm execution.
Definition: ReadTES.cpp:44
CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > >::msgLevel
MSG::Level msgLevel() const
get the cached level (originally extracted from the embedded MsgStream)
Definition: CommonMessaging.h:148
StatusCode
Definition: StatusCode.h:65
ReadTES
Definition: ReadTES.h:28
endmsg
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202
StatusCode::isFailure
bool isFailure() const
Definition: StatusCode.h:129
StatusCode::SUCCESS
constexpr static const auto SUCCESS
Definition: StatusCode.h:100
DECLARE_COMPONENT
#define DECLARE_COMPONENT(type)
Definition: PluginServiceV1.h:46
DataObject
Definition: DataObject.h:36
ReadTES.h
StatusCode::FAILURE
constexpr static const auto FAILURE
Definition: StatusCode.h:101