Loading [MathJax]/jax/output/SVG/config.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
HiveAlgE.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 #include "HiveAlgE.h"
6 
7 HiveAlgE::HiveAlgE( const std::string& name,
8  ISvcLocator* pSvcLocator ) :
9  ::HiveAlgBase( name, pSvcLocator )
10 {
11 }
12 
13 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
14 HiveAlgE::~HiveAlgE() = default;
15 
16 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
18  ATH_MSG_DEBUG("initialize " << name());
19 
23 
24  // initialize base class
25  return HiveAlgBase::initialize();
26 }
27 
28 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
30 
31  ATH_MSG_DEBUG("execute " << name());
32 
33  sleep();
34 
36  if (!rdh1.isValid()) {
37  ATH_MSG_ERROR ("Could not retrieve HiveDataObj with key " << rdh1.key());
38  return StatusCode::FAILURE;
39  }
40 
42  if (!rdh2.isValid()) {
43  ATH_MSG_ERROR ("Could not retrieve HiveDataObj with key " << rdh2.key());
44  return StatusCode::FAILURE;
45  }
46 
47  ATH_MSG_INFO(" read: " << rdh1.key() << " = " << rdh1->val() );
48  ATH_MSG_INFO(" read: " << rdh2.key() << " = " << rdh2->val() );
49 
51  ATH_CHECK(wrh1.record(std::make_unique< HiveDataObj >(500000 + rdh1->val() + rdh2->val()/10)));
52 
53  ATH_MSG_INFO(" write: " << wrh1.key() << " = " << wrh1->val() );
54 
55 
56  return StatusCode::SUCCESS;
57 
58 }
59 
HiveAlgE.h
Simple Algorithm that reads a HiveDataObj created by HiveAlgB, and one by HiveAlgC,...
HiveAlgE::m_rdh2
SG::ReadHandleKey< HiveDataObj > m_rdh2
Definition: HiveAlgE.h:40
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
HiveAlgE::m_rdh1
SG::ReadHandleKey< HiveDataObj > m_rdh1
Definition: HiveAlgE.h:38
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:67
HiveAlgE::~HiveAlgE
~HiveAlgE()
HiveAlgBase::sleep
unsigned int sleep()
Definition: HiveAlgBase.cxx:40
HiveAlgE::execute
virtual StatusCode execute() override
Definition: HiveAlgE.cxx:29
HiveAlgE::initialize
virtual StatusCode initialize() override
Definition: HiveAlgE.cxx:17
HiveAlgBase::initialize
virtual StatusCode initialize() override
Definition: HiveAlgBase.cxx:23
HiveAlgE::HiveAlgE
HiveAlgE(const std::string &name, ISvcLocator *pSvcLocator)
Definition: HiveAlgE.cxx:7
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
HiveAlgBase
Definition: HiveAlgBase.h:26
HiveAlgE::m_wrh1
SG::WriteHandleKey< HiveDataObj > m_wrh1
Definition: HiveAlgE.h:42
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:240
SG::VarHandleBase::key
virtual const std::string & key() const override final
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleBase.cxx:64
SG::WriteHandle
Definition: StoreGate/StoreGate/WriteHandle.h:73
SG::WriteHandle::record
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.
HiveDataObj::val
void val(int i)
Definition: HiveDataObj.h:22