2 Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
5 /// @author Nils Krumnack
12 #include <AsgMessaging/MessageCheck.h>
13 #include <AsgMessaging/StatusCode.h>
18 // method implementations
23 template<typename T> template<typename T2> SysWriteDecorHandle<T> ::
24 SysWriteDecorHandle (T2 *owner, const std::string& propertyName,
25 const std::string& propertyValue,
26 const std::string& propertyDescription)
27 : AsgMessagingForward (owner), m_decorName (propertyValue)
29 owner->declareProperty (propertyName, m_decorName, propertyDescription);
32 template<typename T> template<typename T2> SysWriteDecorHandle<T> ::
33 SysWriteDecorHandle (const std::string& decorName, T2 *owner)
34 : AsgMessagingForward (owner), m_decorName(decorName)
39 template<typename T> bool SysWriteDecorHandle<T> ::
40 empty () const noexcept
42 return m_decorName.empty();
47 template<typename T> SysWriteDecorHandle<T> ::
48 operator bool () const noexcept
50 return !m_decorName.empty();
55 template<typename T> std::string SysWriteDecorHandle<T> ::
56 getNamePattern () const
58 // So far it is undefined what to return here, it could either be
59 // "decorName" or "objectName.decorName". I'll fill this in once
60 // there is a reason for it to be one or the other.
66 template<typename T> StatusCode SysWriteDecorHandle<T> ::
67 initialize (SysListHandle& sysListHandle, const ISysHandleBase& objectHandle)
69 if (m_objectHandle != nullptr)
71 ANA_MSG_ERROR ("trying to initialize handle twice");
72 return StatusCode::FAILURE;
74 m_objectHandle = &objectHandle;
75 return sysListHandle.addHandle (*this);
80 template<typename T> StatusCode SysWriteDecorHandle<T> ::
81 initialize (SysListHandle& sysListHandle, const ISysHandleBase& objectHandle, SG::AllowEmptyEnum)
84 return initialize (sysListHandle, objectHandle);
86 return StatusCode::SUCCESS;
91 template<typename T> const std::string& SysWriteDecorHandle<T> ::
92 getName (const CP::SystematicSet& sys) const
94 const auto& data = getData (sys);
95 return std::get<0> (data);
100 template<typename T> void SysWriteDecorHandle<T> ::
101 set (const SG::AuxElement& object, const T& value,
102 const CP::SystematicSet& sys) const
104 const auto& data = getData (sys);
105 std::get<1> (data) (object) = value;
110 template<typename T> void SysWriteDecorHandle<T> ::
111 lock (const SG::AuxElement& object,
112 const CP::SystematicSet& sys) const
114 const auto& data = getData (sys);
115 SG::AuxVectorData* cont_nc ATLAS_THREAD_SAFE =
116 const_cast<SG::AuxVectorData*> (object.container());
117 cont_nc->lockDecoration (std::get<1> (data).auxid());
122 template<typename T> CP::SystematicSet SysWriteDecorHandle<T> ::
123 getInputAffecting (const ISystematicsSvc& /*svc*/) const
125 return CP::SystematicSet ();
130 template<typename T> StatusCode SysWriteDecorHandle<T> ::
131 fillSystematics (const ISystematicsSvc& svc,
132 const CP::SystematicSet& fullAffecting,
133 const std::vector<CP::SystematicSet>& sysList)
135 for (auto& sys : sysList)
138 ANA_CHECK (svc.makeSystematicsName (newName, m_decorName, sys));
139 ANA_MSG_DEBUG ("SysWriteDecorHandle: " << newName << " (" << sys.name() << ")");
140 m_dataCache.emplace (sys, std::make_tuple (newName, newName));
142 ANA_CHECK (svc.setDecorSystematics (m_objectHandle->getNamePattern(), m_decorName, fullAffecting));
143 return StatusCode::SUCCESS;
148 template<typename T> const auto&
149 SysWriteDecorHandle<T> ::
150 getData (const CP::SystematicSet& sys) const
152 auto cache = m_dataCache.find (sys);
153 if (cache == m_dataCache.end())
155 if (m_dataCache.empty())
156 throw std::logic_error ("uninitialized SysWriteDecorHandle (" + m_decorName + ")");
158 throw std::logic_error ("unsupported systematic in SysWriteDecorHandle (" + m_decorName + "): (" + sys.name() + ")");
160 return cache->second;