ATLAS Offline Software
AuxContainerBase.h
Go to the documentation of this file.
1 // Dear emacs, this is -*- c++ -*-
2 /*
3  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
4 */
5 #ifndef XAODCORE_AUXCONTAINERBASE_H
6 #define XAODCORE_AUXCONTAINERBASE_H
7 
8 // STL include(s):
9 #include <vector>
10 #include <string>
11 #include <memory>
12 
13 // EDM include(s):
20 #include "CxxUtils/CachedPointer.h"
22 #include "SGCore/ILockable.h"
23 
24 // Local include(s):
25 #include "xAODCore/AuxSelection.h"
26 
27 // Forward declaration(s):
28 namespace SG {
29  class IAuxTypeVector;
30 }
32 namespace std { namespace pmr {
33 class memory_resource;
34 }}
35 
37 namespace xAOD {
38 
52  public SG::IAuxStoreIO,
53  public SG::IAuxStoreHolder,
54  public ILockable
55  {
56 
57  public:
62 
64  AuxContainerBase( bool allowDynamicVars = true );
66  AuxContainerBase( std::pmr::memory_resource* memResource,
67  bool allowDynamicVars = true );
72  std::pmr::memory_resource* memResource = nullptr );
75 
78 
81 
83  virtual SG::IAuxStore* getStore() override;
84  virtual const SG::IAuxStore* getStore() const override;
86  virtual void setStore( SG::IAuxStore* store ) override;
88  virtual AuxStoreType getStoreType() const override { return AST_ContainerStore; }
89 
91  std::pmr::memory_resource* memResource();
92 
94 
97 
99  virtual const void* getData( auxid_t auxid ) const override;
100 
102  virtual const SG::IAuxTypeVector* getVector (SG::auxid_t auxid) const override final;
103 
105  virtual const auxid_set_t& getAuxIDs() const override;
106 
108  virtual const auxid_set_t& getDecorIDs() const override;
109 
111  virtual bool isDecoration (auxid_t auxid) const override;
112 
114  virtual void* getDecoration( auxid_t auxid, size_t size,
115  size_t capacity ) override;
116 
118  virtual void lock() override;
119 
121  virtual bool clearDecorations() override;
122 
124  virtual size_t size() const override;
125 
127  virtual void lockDecoration (SG::auxid_t auxid) override;
128 
130  virtual const SG::IAuxTypeVector* linkedVector (SG::auxid_t auxid) const override;
131 
133 
136 
138  virtual void* getData( auxid_t auxid, size_t size,
139  size_t capacity ) override;
140 
142  virtual const auxid_set_t& getWritableAuxIDs() const override;
143 
145  virtual bool resize( size_t size ) override;
147  virtual void reserve( size_t size ) override;
149  virtual void shift( size_t pos, ptrdiff_t offs ) override;
151  virtual bool insertMove (size_t pos,
152  IAuxStore& other,
153  const SG::auxid_set_t& ignore) override;
155  virtual bool setOption( auxid_t id, const SG::AuxDataOption& option ) override;
156 
158  virtual SG::IAuxTypeVector* linkedVector (SG::auxid_t auxid) override;
159 
161 
164 
166  virtual const void* getIOData( auxid_t auxid ) const override;
167 
169  virtual const std::type_info* getIOType( auxid_t auxid ) const override;
170 
172  virtual const auxid_set_t& getDynamicAuxIDs() const override;
173 
175  virtual SG::auxid_set_t getSelectedAuxIDs() const override;
176 
178 
181 
183  const char* name() const;
185  void setName( const char* name );
186 
188 
190  template <class T, class ALLOC = std::allocator<T> >
191  using AuxVariable_t = std::vector<T, ALLOC>;
192  template <class T, class ALLOC = std::allocator<T> >
194 
196  template< typename T, typename ALLOC >
197  auxid_t getAuxID( const std::string& name,
198  std::vector< T, ALLOC >& /*vec*/,
201  const SG::auxid_t linkedVariable = SG::null_auxid );
203  template< typename T >
204  auxid_t getAuxID( const std::string& name,
205  SG::PackedContainer< T >& /*vec*/,
208  const SG::auxid_t linkedVariable = SG::null_auxid );
210  template< typename T, typename ALLOC >
211  void regAuxVar( auxid_t auxid, const std::string& name,
212  std::vector< T, ALLOC >& vec );
213 
215  template< typename T >
216  void regAuxVar( auxid_t auxid, const std::string& name,
218 
219  private:
220  friend class ::xAODAuxContainerBaseCnv;
221 
223  template< typename ELT, typename CONT >
224  void regAuxVar1( auxid_t auxid, const std::string& name,
225  CONT& vec );
226 
230  std::vector< SG::IAuxTypeVector* > m_vecs;
231 
239  bool m_locked;
240 
243  typedef AthContainers_detail::lock_guard< mutex_t > guard_t;
244  mutable mutex_t m_mutex;
245 
247  std::string m_name;
248 
251 
252  }; // class AuxContainerBase
253 
254 } // namespace xAOD
255 
256 // Declare a class ID for the class:
257 #include "xAODCore/CLASS_DEF.h"
258 CLASS_DEF( xAOD::AuxContainerBase, 1225080690, 3 )
259 
260 // Describe the inheritance of the class:
261 #include "xAODCore/BaseInfo.h"
264 
265 // Include the template implementation:
266 #include "AuxContainerBase.icc"
267 
268 #endif // XAODCORE_AUXCONTAINERBASE_H
xAOD::AuxContainerBase::m_name
std::string m_name
Name of the container in memory. Set externally.
Definition: AuxContainerBase.h:247
xAOD::AuxContainerBase::lock
virtual void lock() override
Lock the container.
Definition: AuxContainerBase.cxx:345
xAOD::AuxContainerBase::setStore
virtual void setStore(SG::IAuxStore *store) override
Set a different internal store object.
Definition: AuxContainerBase.cxx:197
SGTest::store
TestStore store
Definition: TestStore.cxx:23
SG_BASES3
SG_BASES3(xAOD::AuxContainerBase, SG::IAuxStore, SG::IAuxStoreIO, SG::IAuxStoreHolder)
xAOD::AuxContainerBase::getIOType
virtual const std::type_info * getIOType(auxid_t auxid) const override
Return the type of the data to be stored for one aux data item.
Definition: AuxContainerBase.cxx:686
xAOD::AuxContainerBase::name
const char * name() const
Get the name of the container instance.
Definition: AuxContainerBase.cxx:745
PackedContainer.h
Container to hold aux data to be stored in a packed form.
IAuxStoreHolder.h
SG
Forward declaration.
Definition: CaloCellPacker_400_500.h:32
xAOD::AuxContainerBase::clearDecorations
virtual bool clearDecorations() override
Clear all decorations.
Definition: AuxContainerBase.cxx:359
xAOD::AuxContainerBase::m_store
SG::IAuxStore * m_store
Internal dynamic auxiliary store object.
Definition: AuxContainerBase.h:233
xAOD::AuxContainerBase::memResource
std::pmr::memory_resource * memResource()
Return the memory resource to use.
Definition: AuxContainerBase.cxx:161
AthenaPoolTestRead.flags
flags
Definition: AthenaPoolTestRead.py:8
BeamSpot::mutex
std::mutex mutex
Definition: InDetBeamSpotVertex.cxx:18
xAOD::AuxContainerBase::linkedVector
virtual const SG::IAuxTypeVector * linkedVector(SG::auxid_t auxid) const override
Return interface for a linked variable.
Definition: AuxContainerBase.cxx:398
xAOD::AuxContainerBase::operator=
AuxContainerBase & operator=(const AuxContainerBase &rhs)
Assignment operator.
Definition: AuxContainerBase.cxx:121
xAOD::AuxContainerBase::guard_t
AthContainers_detail::lock_guard< mutex_t > guard_t
Definition: AuxContainerBase.h:243
xAOD::AuxContainerBase::getAuxIDs
virtual const auxid_set_t & getAuxIDs() const override
Get the types(names) of variables handled by this container.
Definition: AuxContainerBase.cxx:277
xAOD::AuxContainerBase::setOption
virtual bool setOption(auxid_t id, const SG::AuxDataOption &option) override
Make an option setting on an aux variable.
Definition: AuxContainerBase.cxx:640
xAOD::AuxContainerBase::isDecoration
virtual bool isDecoration(auxid_t auxid) const override
Test if a variable is a decoration.
Definition: AuxContainerBase.cxx:293
ILockable.h
xAOD::AuxContainerBase
Common base class for the auxiliary containers.
Definition: AuxContainerBase.h:55
xAOD::other
@ other
Definition: TrackingPrimitives.h:510
xAOD
ICaloAffectedTool is abstract interface for tools checking if 4 mom is in calo affected region.
Definition: ICaloAffectedTool.h:24
vec
std::vector< size_t > vec
Definition: CombinationsGeneratorTest.cxx:9
xAODAuxContainerBaseCnv
POOL converter for the xAOD::AuxContainerBase class.
Definition: xAODAuxContainerBaseCnv.h:32
xAOD::AuxContainerBase::getStoreType
virtual AuxStoreType getStoreType() const override
Return the type of the store object.
Definition: AuxContainerBase.h:88
xAOD::AuxContainerBase::m_mutex
mutex_t m_mutex
Definition: AuxContainerBase.h:244
xAOD::AuxContainerBase::resize
virtual bool resize(size_t size) override
Resize the arrays to a given size.
Definition: AuxContainerBase.cxx:507
AuxContainerBase.icc
xAOD::AuxContainerBase::~AuxContainerBase
~AuxContainerBase()
Destructor.
Definition: AuxContainerBase.cxx:102
CachedPointer.h
Cached pointer with atomic update.
SG::IAuxStoreIO
Interface providing I/O for a generic auxiliary store.
Definition: IAuxStoreIO.h:44
xAOD::AuxContainerBase::getStore
virtual SG::IAuxStore * getStore() override
Get the currently used internal store object.
Definition: AuxContainerBase.cxx:156
xAOD::AuxContainerBase::size
virtual size_t size() const override
Get the size of the container.
Definition: AuxContainerBase.cxx:432
SG::IAuxStoreHolder::AuxStoreType
AuxStoreType
Type of the auxiliary store.
Definition: IAuxStoreHolder.h:66
DiTauMassTools::ignore
void ignore(T &&)
Definition: PhysicsAnalysis/TauID/DiTauMassTools/DiTauMassTools/HelperFunctions.h:58
xAOD::AuxContainerBase::regAuxVar1
void regAuxVar1(auxid_t auxid, const std::string &name, CONT &vec)
Common code between regAuxVar cases.
xAOD::AuxContainerBase::getDynamicAuxIDs
virtual const auxid_set_t & getDynamicAuxIDs() const override
Get the types(names) of variables created dynamically.
Definition: AuxContainerBase.cxx:703
xAOD::AuxContainerBase::reserve
virtual void reserve(size_t size) override
Reserve a given size for the arrays.
Definition: AuxContainerBase.cxx:535
SG::auxid_t
size_t auxid_t
Identifier for a particular aux data item.
Definition: AuxTypes.h:27
xAOD::AuxContainerBase::regAuxVar
void regAuxVar(auxid_t auxid, const std::string &name, SG::PackedContainer< T > &vec)
Register one of the persistent variables internally.
CaloCellPos2Ntuple.None
None
Definition: CaloCellPos2Ntuple.py:23
xAOD::AuxContainerBase::auxid_set_t
SG::auxid_set_t auxid_set_t
The aux ID set type definition.
Definition: AuxContainerBase.h:61
xAOD::AuxContainerBase::m_auxids
auxid_set_t m_auxids
Internal list of all available variables.
Definition: AuxContainerBase.h:228
xAOD::AuxContainerBase::m_vecs
std::vector< SG::IAuxTypeVector * > m_vecs
Internal list of all managed variables.
Definition: AuxContainerBase.h:230
xAOD::AuxContainerBase::regAuxVar
void regAuxVar(auxid_t auxid, const std::string &name, std::vector< T, ALLOC > &vec)
Register one of the persistent variables internally.
IAuxStoreIO.h
Interface providing I/O for a generic auxiliary store.
xAOD::AuxContainerBase::shift
virtual void shift(size_t pos, ptrdiff_t offs) override
Shift the contents of the stored arrays.
Definition: AuxContainerBase.cxx:560
test_pyathena.parent
parent
Definition: test_pyathena.py:15
xAOD::AuxContainerBase::getDecorIDs
virtual const auxid_set_t & getDecorIDs() const override
Get the types(names) of decorations handled by this container.
Definition: AuxContainerBase.cxx:284
xAOD::AuxContainerBase::getDecoration
virtual void * getDecoration(auxid_t auxid, size_t size, size_t capacity) override
Get a pointer to a given array, as a decoration.
Definition: AuxContainerBase.cxx:302
SG::AuxVarFlags
AuxVarFlags
Additional flags to qualify an auxiliary variable.
Definition: AuxTypes.h:58
SG::AuxDataOption
Hold information about an option setting request.
Definition: AuxDataOption.h:37
xAOD::AuxContainerBase::getSelectedAuxIDs
virtual SG::auxid_set_t getSelectedAuxIDs() const override
Get the IDs of the selected dynamic Aux variables (for writing)
Definition: AuxContainerBase.cxx:723
xAOD::AuxContainerBase::getVector
virtual const SG::IAuxTypeVector * getVector(SG::auxid_t auxid) const override final
Return vector interface for one aux data item.
Definition: AuxContainerBase.cxx:241
xAOD::AuxContainerBase::getWritableAuxIDs
virtual const auxid_set_t & getWritableAuxIDs() const override
Return a set of writable data identifiers.
Definition: AuxContainerBase.cxx:500
xAOD::AuxContainerBase::getData
virtual const void * getData(auxid_t auxid) const override
Get a pointer to a given array.
Definition: AuxContainerBase.cxx:232
threading.h
Threading definitions.
CLASS_DEF.h
File providing the different SG_BASE macros.
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:16
xAOD::AuxContainerBase::auxid_t
SG::auxid_t auxid_t
The aux ID type definition.
Definition: AuxContainerBase.h:59
SG::IAuxStore
Interface for non-const operations on an auxiliary store.
Definition: IAuxStore.h:48
xAOD::AuxContainerBase::ATLAS_THREAD_SAFE
CxxUtils::CachedPointer< std::pmr::memory_resource > m_memResource ATLAS_THREAD_SAFE
Memory resource to use for this container.
Definition: AuxContainerBase.h:250
AuxSelection.h
SG::PackedContainer
Container to hold aux data to be stored in a packed form.
Definition: PackedContainer.h:50
xAOD::AuxContainerBase::mutex_t
AthContainers_detail::mutex mutex_t
Mutex for multithread synchronization.
Definition: AuxContainerBase.h:242
CxxUtils::CachedPointer< std::pmr::memory_resource >
xAOD::AuxContainerBase::insertMove
virtual bool insertMove(size_t pos, IAuxStore &other, const SG::auxid_set_t &ignore) override
Insert contents of another store via move.
Definition: AuxContainerBase.cxx:586
xAOD::AuxContainerBase::m_locked
bool m_locked
Has the container been locked?
Definition: AuxContainerBase.h:239
CLASS_DEF
#define CLASS_DEF(NAME, CID, VERSION)
associate a clid and a version to a type eg
Definition: Control/AthenaKernel/AthenaKernel/CLASS_DEF.h:67
SG::IAuxTypeVector
Abstract interface for manipulating vectors of arbitrary types.
Definition: IAuxTypeVector.h:42
xAOD::AuxContainerBase::lockDecoration
virtual void lockDecoration(SG::auxid_t auxid) override
Lock a decoration.
Definition: AuxContainerBase.cxx:389
xAOD::AuxContainerBase::m_ownsStore
bool m_ownsStore
Flag deciding if the object owns the dynamic store or not.
Definition: AuxContainerBase.h:237
AuxTypeRegistry.h
Handle mappings between names and auxid_t.
IAuxStore.h
Interface for non-const operations on an auxiliary store.
ILockable
Interface to allow an object to lock itself when made const in SG.
Definition: ILockable.h:32
xAOD::AuxContainerBase::m_storeIO
SG::IAuxStoreIO * m_storeIO
The IO interface to the internal auxiliary store.
Definition: AuxContainerBase.h:235
xAOD::AuxContainerBase::AuxContainerBase
AuxContainerBase(bool allowDynamicVars=true)
Default constructor.
Definition: AuxContainerBase.cxx:33
xAOD::AuxContainerBase::getIOData
virtual const void * getIOData(auxid_t auxid) const override
Get a pointer to the data being stored for one aux data item.
Definition: AuxContainerBase.cxx:661
xAOD::AuxContainerBase::getAuxID
auxid_t getAuxID(const std::string &name, std::vector< T, ALLOC > &, SG::AuxVarFlags flags=SG::AuxVarFlags::None, const SG::auxid_t linkedVariable=SG::null_auxid)
Get the auxiliary ID for one of the persistent variables.
SG::auxid_set_t
A set of aux data identifiers.
Definition: AuxTypes.h:47
xAOD::AuxContainerBase::getAuxID
auxid_t getAuxID(const std::string &name, SG::PackedContainer< T > &, SG::AuxVarFlags flags=SG::AuxVarFlags::None, const SG::auxid_t linkedVariable=SG::null_auxid)
Get the auxiliary ID for one of the persistent variables.
xAOD::AuxContainerBase::setName
void setName(const char *name)
Set the name of the container instance.
Definition: AuxContainerBase.cxx:750
checker_macros.h
Define macros for attributes used to control the static checker.
SG::IAuxStoreHolder
Interface for objects taking part in direct ROOT I/O.
Definition: IAuxStoreHolder.h:36
xAOD::AuxContainerBase::LinkedVariable_t
AuxVariable_t< T, ALLOC > LinkedVariable_t
Definition: AuxContainerBase.h:193
xAOD::AuxContainerBase::AuxVariable_t
std::vector< T, ALLOC > AuxVariable_t
Declare how to wrap variables for this sort of base.
Definition: AuxContainerBase.h:191
SG::IAuxStoreHolder::AST_ContainerStore
@ AST_ContainerStore
The store describes a container.
Definition: IAuxStoreHolder.h:68