 |
ATLAS Offline Software
|
Go to the documentation of this file.
8 #ifndef COLUMNAR_CORE_OPT_OBJECT_ID_H
9 #define COLUMNAR_CORE_OPT_OBJECT_ID_H
24 template<ContainerIdConcept CI,
typename CM>
class OptObjectId;
43 : m_object (&val_object.getXAODObjectNoexcept())
47 : m_object (val_object)
55 return m_object !=
nullptr;}
58 return m_object !=
nullptr;}
61 if (m_object ==
nullptr)
62 throw std::bad_optional_access();
70 if (m_object ==
nullptr)
71 throw std::bad_optional_access();
82 return m_object == that.m_object;}
93 template<ContainerIdConcept CI>
99 template<ContainerIdConcept CI>
121 :
m_data (val_object.getData()), m_index (val_object.getIndex())
130 throw std::logic_error (
"can't call xAOD function in columnar mode");
142 throw std::logic_error (
"can't call xAOD function in columnar mode");}
152 throw std::bad_optional_access();
157 throw std::bad_optional_access();
161 return m_index == that.m_index;}
170 :
m_data (val_data), m_index (val_index)
173 explicit OptObjectId (
void **val_data,
unsigned val_index) noexcept
174 :
m_data (val_data), m_index (val_index)
177 explicit OptObjectId (
void **val_data, std::size_t val_index) noexcept
178 :
m_data (val_data), m_index (val_index)
197 template<ContainerIdConcept CI>
203 template<ContainerIdConcept CI>
ObjectId< CI, ColumnarModeXAOD > value() const
OptObjectId(xAODObject *)
xAODObject * getXAODObject() const
typename CI::xAODObjectIdType xAODObject
void ** getData() const noexcept
a class representing a single optional object (electron, muons, etc.)
AccessorTemplate & operator=(AccessorTemplate &&that)
bool const RAWDATA *ch2 const
std::map< std::string, HypoJetVector >::const_iterator CI
OptObjectId(const OptObjectId< CI, ColumnarModeArray > &that) noexcept=default
bool operator==(const ObjectId< CI, ColumnarModeXAOD > &lhs, const ObjectId< CI, ColumnarModeXAOD > &rhs)
xAODObject * getXAODObjectNoexcept() const noexcept
OptObjectId(ObjectId< CI, ColumnarModeXAOD > val_object) noexcept
bool operator!=(const ObjectId< CI, ColumnarModeXAOD > &lhs, const ObjectId< CI, ColumnarModeXAOD > &rhs)
SiLocalPosition operator*(const SiLocalPosition &position, const double factor)
OptObjectId(void **val_data, std::size_t val_index) noexcept
xAODObject * getXAODObject() const noexcept
constexpr ColumnarOffsetType invalidObjectIndex
the value for an invalid element index
bool has_value() const noexcept
ObjectId< CI, ColumnarModeArray > value() const
OptObjectId(void **val_data, int val_index) noexcept
OptObjectId() noexcept=default
OptObjectId(ObjectId< CI, ColumnarModeArray > val_object) noexcept
bool has_value() const noexcept
OptObjectId(void **val_data, unsigned val_index) noexcept
OptObjectId(const OptObjectId< CI, ColumnarModeXAOD > &that) noexcept=default
#define ATLAS_THREAD_SAFE
std::size_t getIndex() const noexcept
setBGCode setTAP setLVL2ErrorBits bool
OptObjectId() noexcept=default
OptObjectId(xAODObject *val_object) noexcept
typename CI::xAODObjectIdType xAODObject