ATLAS Offline Software
Public Member Functions | Static Public Attributes | Protected Types | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
TBranchAuxDynStore Class Reference

#include <TBranchAuxDynStore.h>

Inheritance diagram for TBranchAuxDynStore:
Collaboration diagram for TBranchAuxDynStore:

Public Member Functions

 TBranchAuxDynStore (TBranchAuxDynReader &reader, long long entry, bool standalone, std::recursive_mutex *iomtx=nullptr)
 
virtual ~TBranchAuxDynStore ()
 
virtual const void * getData (SG::auxid_t auxid) const override
 implementation of the IAuxStore interface More...
 
virtual void * getData (SG::auxid_t auxid, size_t size, size_t capacity) override
 Return the data vector for one aux data item. More...
 
virtual const void * getData (SG::auxid_t auxid) const=0
 Pick up the const version from the base class. More...
 
virtual const SG::IAuxTypeVectorgetVector (SG::auxid_t auxid) const override
 Return vector interface for one aux data item. More...
 
virtual const void * getIOData (SG::auxid_t auxid) const override
 implementation of the IAuxStoreIO interface More...
 
virtual void * getDecoration (SG::auxid_t auxid, size_t size, size_t capacity) override
 Return the data vector for one aux data decoration item. More...
 
virtual bool isDecoration (SG::auxid_t auxid) const override
 Test if a particular variable is tagged as a decoration. More...
 
virtual size_t size () const override
 Return the number of elements in the store. More...
 
bool standalone () const
 Return the standalone flag. More...
 
virtual bool resize (size_t sz) override
 Change the size of all aux data vectors. More...
 
virtual void reserve (size_t sz) override
 Change the capacity of all aux data vectors. More...
 
virtual void shift (size_t pos, ptrdiff_t offs) override
 Shift the elements of the container. More...
 
virtual bool insertMove (size_t pos, IAuxStore &other, const SG::auxid_set_t &ignore=SG::auxid_set_t(0)) override
 Move all elements from other to this store. More...
 
virtual const SG::auxid_set_tgetAuxIDs () const override
 Return a set of identifiers for existing data items in this store. More...
 
virtual const SG::auxid_set_tgetDecorIDs () const override
 Return a set of identifiers for decorations in this store. More...
 
virtual const SG::auxid_set_tgetWritableAuxIDs () const override
 Return a set of identifiers for writable data items in this store. More...
 
virtual const std::type_info * getIOType (SG::auxid_t auxid) const override
 Return the type of the data to be stored for one aux data item. More...
 
virtual const SG::auxid_set_tgetDynamicAuxIDs () const override
 Get the list of all variables that need to be handled. More...
 
virtual void lock () override
 Lock the container. More...
 
virtual bool clearDecorations () override
 Clear all decorations. More...
 
virtual bool setOption (auxid_t id, const AuxDataOption &option) override
 Set an option for an auxiliary data variable. More...
 
virtual void lockDecoration (SG::auxid_t auxid) override
 Lock a decoration. More...
 
virtual IAuxTypeVector * linkedVector (SG::auxid_t auxid) override
 Return interface for a linked variable. More...
 
virtual const IAuxTypeVector * linkedVector (SG::auxid_t auxid) const override
 Return interface for a linked variable. More...
 
virtual const IAuxTypeVector * linkedVector (SG::auxid_t) const
 Return interface for a linked variable. More...
 
virtual SG::auxid_set_t getSelectedAuxIDs () const
 Get a list of dynamic variables that need to be written out. More...
 

Static Public Attributes

static constexpr bool supportsThinning = true
 Mark that this type supports thinning operations. More...
 

Protected Types

typedef AthContainers_detail::mutex mutex_t
 Mutex used to synchronize modifications to the cache vector. More...
 
typedef AthContainers_detail::lock_guard< mutex_tguard_t
 

Protected Member Functions

virtual bool readData (SG::auxid_t auxid) override final
 read data from ROOT and store it in m_vecs. Returns False on error More...
 
const void * getIODataInternal (auxid_t auxid, bool quiet) const
 Return a pointer to the data to be stored for one aux data item. More...
 
void * getIODataInternal (auxid_t auxid, bool quiet)
 Return a pointer to the data to be stored for one aux data item. More...
 
void addAuxID (auxid_t auxid)
 Add a new auxid to the set of those being managed by this store. More...
 
virtual void * getDataInternal (SG::auxid_t auxid, size_t size, size_t capacity, bool no_lock_check)
 Return the data vector for one aux data item. More...
 
void addVector (std::unique_ptr< IAuxTypeVector > vec, bool isDecoration)
 Explicitly add a vector to the store. More...
 

Protected Attributes

TBranchAuxDynReaderm_reader
 
long long m_entry
 
mutex_t m_mutex
 
std::recursive_mutex * m_iomutex
 Optional mutex used to serialize I/O with RootStorageSvc (not owned) More...
 

Private Member Functions

virtual IAuxTypeVector * getVectorInternal_noLock (SG::auxid_t auxid, size_t size, size_t capacity, bool no_lock_check)
 Implementation of getVectorInternal; no locking. More...
 
size_t size_noLock () const
 Return the number of elements in the store; no locking. More...
 

Private Attributes

bool m_standalone
 Are we being written in standalone mode? More...
 
std::vector< std::unique_ptr< IAuxTypeVector > > m_vecs
 The collection of vectors of aux data that we're managing, indexed by auxid. More...
 
SG::auxid_set_t m_decorations
 Record which variables are decorations. More...
 
SG::auxid_set_t m_auxids
 Set of auxid's for which we've created a vector. More...
 
bool m_locked
 Has this container been locked? More...
 

Detailed Description

Definition at line 20 of file TBranchAuxDynStore.h.

Member Typedef Documentation

◆ guard_t

typedef AthContainers_detail::lock_guard<mutex_t> RootAuxDynStore::guard_t
protectedinherited

Definition at line 66 of file RootAuxDynStore.h.

◆ mutex_t

typedef AthContainers_detail::mutex RootAuxDynStore::mutex_t
protectedinherited

Mutex used to synchronize modifications to the cache vector.

Definition at line 65 of file RootAuxDynStore.h.

Constructor & Destructor Documentation

◆ TBranchAuxDynStore()

TBranchAuxDynStore::TBranchAuxDynStore ( TBranchAuxDynReader reader,
long long  entry,
bool  standalone,
std::recursive_mutex *  iomtx = nullptr 
)

Definition at line 17 of file TBranchAuxDynStore.cxx.

19  : RootAuxDynStore( reader, entry, standalone, iomtx ),
21 {
22 }

◆ ~TBranchAuxDynStore()

virtual TBranchAuxDynStore::~TBranchAuxDynStore ( )
inlinevirtual

Definition at line 26 of file TBranchAuxDynStore.h.

26 {}

Member Function Documentation

◆ addAuxID()

void SG::AuxStoreInternal::addAuxID ( auxid_t  auxid)
protectedinherited

Add a new auxid to the set of those being managed by this store.

Parameters
auxidThe auxid to add.

Definition at line 676 of file AuxStoreInternal.cxx.

677 {
678  m_auxids.insert (auxid);
679 }

◆ addVector()

void SG::AuxStoreInternal::addVector ( std::unique_ptr< IAuxTypeVector vec,
bool  isDecoration 
)
protectedinherited

Explicitly add a vector to the store.

Parameters
vecVector data being added.
isDecorationShould this variable be marked as a decoration?

For internal use. The auxid must not already exist in the store.

Definition at line 144 of file AuxStoreInternal.cxx.

146 {
147  guard_t guard (m_mutex);
148  auxid_t auxid = vec->auxid();
149  if (m_locked)
150  throw ExcStoreLocked (auxid);
151 
152  // Resize the vector if needed.
153  if (m_vecs.size() <= auxid) {
154  m_vecs.resize (auxid+1);
155  }
156 
157  // Give up if the variable is already present in the store.
158  if (m_vecs[auxid]) std::abort();
159 
160  // Make sure the length is consistent with the rest of the store.
161  if (!vec->isLinked()) {
162  size_t sz = this->size_noLock();
163  if (vec->size() < sz)
164  vec->resize (sz);
165  }
166 
167  // Add it to the store.
168  m_vecs[auxid] = std::move (vec);
169  addAuxID (auxid);
170  if (isDecoration) {
171  m_decorations.insert (auxid);
172  }
173 }

◆ clearDecorations()

bool SG::AuxStoreInternal::clearDecorations ( )
overridevirtualinherited

Clear all decorations.

Erase all decorations from the store, restoring the state to when lock was called. Be sure to clear the cache of the referencing container!

Returns true if there were any decorations that were cleared, false if the store did not contain any decorations.

Implements SG::IConstAuxStore.

Definition at line 581 of file AuxStoreInternal.cxx.

582 {
583  guard_t guard (m_mutex);
584  bool anycleared = false;
585  for (auxid_t id : m_decorations) {
586  m_vecs[id].reset();
587  m_auxids.erase (id);
588  anycleared = true;
589  }
590  if (anycleared) {
592  }
593  return anycleared;
594 }

◆ getAuxIDs()

const SG::auxid_set_t & SG::AuxStoreInternal::getAuxIDs ( ) const
overridevirtualinherited

Return a set of identifiers for existing data items in this store.

This should include identifiers for all items, const and non-const.

Implements SG::IConstAuxStore.

Definition at line 400 of file AuxStoreInternal.cxx.

401 {
402  return m_auxids;
403 }

◆ getData() [1/3]

const void * RootAuxDynStore::getData ( SG::auxid_t  auxid) const
overridevirtualinherited

implementation of the IAuxStore interface

Reimplemented from SG::AuxStoreInternal.

Definition at line 25 of file RootAuxDynStore.cxx.

26 {
27  const SG::IAuxTypeVector* v = getVector( auxid );
28  if( v ) {
29  return v->toPtr();
30  }
31  return nullptr;
32 }

◆ getData() [2/3]

virtual const void* SG::IConstAuxStore::getData
inherited

Pick up the const version from the base class.

◆ getData() [3/3]

void * RootAuxDynStore::getData ( SG::auxid_t  auxid,
size_t  size,
size_t  capacity 
)
overridevirtualinherited

Return the data vector for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.
sizeThe current size of the container (in case the data item does not already exist).
capacityThe current capacity of the container (in case the data item does not already exist).

Each aux data item is stored as a vector, with one entry per entry in the owning container. This returns a pointer to the start of the vector.

If the data item does not exist, it should be created and initialized to default values. size and capacity give the size for the new aux data item vector.

Reimplemented from SG::AuxStoreInternal.

Definition at line 50 of file RootAuxDynStore.cxx.

51 {
52  // MN: how do we add new attributes to this store? A:for now we don't
53  throw("Non-const access to RootAuxDynStore is not supported");
54 }

◆ getDataInternal()

void * SG::AuxStoreInternal::getDataInternal ( SG::auxid_t  auxid,
size_t  size,
size_t  capacity,
bool  no_lock_check 
)
protectedvirtualinherited

Return the data vector for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.
sizeThe current size of the container (in case the data item does not already exist).
capacityThe current capacity of the container (in case the data item does not already exist).
no_lock_checkIf true, then skip the test for a locked container.

Each aux data item is stored as a vector, with one entry per entry in the owning container. This returns a pointer to the start of the vector.

If the data item does not exist, it should be created and initialized to default values. size and capacity give the size for the new aux data item vector.

Definition at line 735 of file AuxStoreInternal.cxx.

739 {
740  guard_t guard (m_mutex);
741  return getVectorInternal_noLock (auxid, size, capacity, no_lock_check)->toPtr();
742 }

◆ getDecoration()

void * RootAuxDynStore::getDecoration ( SG::auxid_t  auxid,
size_t  size,
size_t  capacity 
)
overridevirtualinherited

Return the data vector for one aux data decoration item.

Parameters
auxidThe identifier of the desired aux data item.
sizeThe current size of the container (in case the data item does not already exist).
capacityThe current capacity of the container (in case the data item does not already exist).
auxidThe identifier of the desired aux data item.
sizeThe current size of the container (in case the data item does not already exist).
capacityThe current capacity of the container (in case the data item does not already exist).

Each aux data item is stored as a vector, with one entry per entry in the owning container. This returns a pointer to the start of the vector.

The base class implementation works except for the case where we have not yet created a vector for an item in the root file. We need to detect that case and raise an exception.

Reimplemented from SG::AuxStoreInternal.

Definition at line 87 of file RootAuxDynStore.cxx.

88 {
89  guard_t guard (m_mutex);
90  if (SG::AuxStoreInternal::getIODataInternal (auxid, true) == 0 &&
92  {
93  throw SG::ExcStoreLocked (auxid);
94  }
95  return SG::AuxStoreInternal::getDecoration (auxid, size, capacity);
96 }

◆ getDecorIDs()

const SG::auxid_set_t & SG::AuxStoreInternal::getDecorIDs ( ) const
overridevirtualinherited

Return a set of identifiers for decorations in this store.

Implements SG::IConstAuxStore.

Definition at line 410 of file AuxStoreInternal.cxx.

411 {
412  return m_decorations;
413 }

◆ getDynamicAuxIDs()

const SG::auxid_set_t & SG::AuxStoreInternal::getDynamicAuxIDs ( ) const
overridevirtualinherited

Get the list of all variables that need to be handled.

Implements SG::IAuxStoreIO.

Definition at line 552 of file AuxStoreInternal.cxx.

553 {
554  return getAuxIDs();
555 }

◆ getIOData()

const void * RootAuxDynStore::getIOData ( SG::auxid_t  auxid) const
overridevirtualinherited

implementation of the IAuxStoreIO interface

Reimplemented from SG::AuxStoreInternal.

Definition at line 57 of file RootAuxDynStore.cxx.

58 {
59  guard_t guard (m_mutex);
60  const void* ret = SG::AuxStoreInternal::getIODataInternal (auxid, true);
61  if (!ret) {
62  auto this_nc ATLAS_THREAD_SAFE = const_cast<RootAuxDynStore*>(this); // locked above
63  if( this_nc->readData(auxid) ) {
64  ret = SG::AuxStoreInternal::getIOData (auxid);
65  }
66  }
67  return ret;
68 }

◆ getIODataInternal() [1/2]

void * SG::AuxStoreInternal::getIODataInternal ( auxid_t  auxid,
bool  quiet 
)
protectedinherited

Return a pointer to the data to be stored for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.
quietIf true, then don't print an error on failure.

This will usually be a pointer to a std::vector; however, it may be something different for a standalone object.

Returns 0 and reports an error if the requested aux data item does not exist.

Definition at line 483 of file AuxStoreInternal.cxx.

484 {
485  guard_t guard (m_mutex);
486  if (auxid >= m_vecs.size() || !m_vecs[auxid]) {
487  if (!quiet) {
488  std::ostringstream ss;
489  ss << "Requested variable "
491  << " (" << auxid << ") doesn't exist";
492  ATHCONTAINERS_ERROR("AuxStoreInternal::getIODataInternal", ss.str());
493  }
494  return 0;
495  }
496 
497  if (m_standalone) {
498  if (!SG::AuxTypeRegistry::instance().isLinked (auxid))
499  return m_vecs[auxid]->toPtr();
500  }
501  return m_vecs[auxid]->toVector();
502 }

◆ getIODataInternal() [2/2]

const void * SG::AuxStoreInternal::getIODataInternal ( auxid_t  auxid,
bool  quiet 
) const
protectedinherited

Return a pointer to the data to be stored for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.
quietIf true, then don't print an error on failure.

This will usually be a pointer to a std::vector; however, it may be something different for a standalone object.

Returns 0 and reports an error if the requested aux data item does not exist.

Definition at line 450 of file AuxStoreInternal.cxx.

451 {
452  guard_t guard (m_mutex);
453  if (auxid >= m_vecs.size() || !m_vecs[auxid]) {
454  if (!quiet) {
455  std::ostringstream ss;
456  ss << "Requested variable "
458  << " (" << auxid << ") doesn't exist";
459  ATHCONTAINERS_ERROR("AuxStoreInternal::getIODataInternal", ss.str());
460  }
461  return 0;
462  }
463 
464  if (m_standalone) {
465  if (!SG::AuxTypeRegistry::instance().isLinked (auxid))
466  return m_vecs[auxid]->toPtr();
467  }
468  return m_vecs[auxid]->toVector();
469 }

◆ getIOType()

const std::type_info * SG::AuxStoreInternal::getIOType ( SG::auxid_t  auxid) const
overridevirtualinherited

Return the type of the data to be stored for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.

For an aux data item of type T, this will usually be std::vector<T>. For standalone objects, however, it will usually be T; and std::vector<char> will be used instead of std::vector<bool>.

Returns 0 if the requested aux data item does not exist.

Implements SG::IAuxStoreIO.

Definition at line 532 of file AuxStoreInternal.cxx.

533 {
534  if (m_standalone) {
536  if (!r.isLinked (auxid))
537  return r.getType (auxid);
538  }
539  guard_t guard (m_mutex);
540  if (auxid < m_vecs.size() && m_vecs[auxid]) {
541  const std::type_info* ret = m_vecs[auxid]->objType();
542  if (ret) return ret;
543  }
544  return SG::AuxTypeRegistry::instance().getVecType (auxid);
545 }

◆ getSelectedAuxIDs()

virtual SG::auxid_set_t SG::IAuxStoreIO::getSelectedAuxIDs ( ) const
inlinevirtualinherited

Get a list of dynamic variables that need to be written out.

Reimplemented in xAOD::TAuxStore, xAOD::AuxContainerBase, xAOD::ShallowAuxContainer, xAOD::AuxInfoBase, and xAOD::RAuxStore.

Definition at line 86 of file IAuxStoreIO.h.

86  {
87  // default all are selected
88  return getDynamicAuxIDs();
89  }

◆ getVector()

const SG::IAuxTypeVector * RootAuxDynStore::getVector ( SG::auxid_t  auxid) const
overridevirtualinherited

Return vector interface for one aux data item.

Parameters
auxidThe identifier of the desired aux data item.

This should return nullptr if the item doesn't exist.

Reimplemented from SG::AuxStoreInternal.

Definition at line 35 of file RootAuxDynStore.cxx.

36 {
37  guard_t guard (m_mutex);
38  // lock
40  if (!ret) {
41  auto this_nc ATLAS_THREAD_SAFE = const_cast<RootAuxDynStore*>(this); // locked above
42  if( this_nc->readData(auxid) ) {
43  ret = SG::AuxStoreInternal::getVector (auxid);
44  }
45  }
46  return ret;
47 }

◆ getVectorInternal_noLock()

IAuxTypeVector * SG::AuxStoreInternal::getVectorInternal_noLock ( SG::auxid_t  auxid,
size_t  size,
size_t  capacity,
bool  no_lock_check 
)
privatevirtualinherited

Implementation of getVectorInternal; no locking.

Definition at line 684 of file AuxStoreInternal.cxx.

688 {
689  if (m_vecs.size() <= auxid) {
690  m_vecs.resize (auxid+1);
691  }
692  if (m_vecs[auxid] == 0) {
693  if (m_locked && !no_lock_check)
694  throw ExcStoreLocked (auxid);
695  const AuxTypeRegistry& r = AuxTypeRegistry::instance();
696  m_vecs[auxid] = r.makeVector (auxid, size, capacity);
697  addAuxID (auxid);
698  std::unique_ptr<IAuxTypeVector> linked = m_vecs[auxid]->linkedVector();
699  if (linked) {
700  auxid_t linked_id = linked->auxid();
701  m_vecs[linked_id] = std::move (linked);
702  addAuxID (linked_id);
703  }
704  }
705  else {
706  // Make sure the vector has at least the requested size.
707  // One way in which it could be short: setOption was called and created
708  // a variable in a store that had no other variables.
709  if (m_vecs[auxid]->size() < size) {
710  m_vecs[auxid]->resize (size);
711  m_vecs[auxid]->reserve (capacity);
712  }
713  }
714  return m_vecs[auxid].get();
715 }

◆ getWritableAuxIDs()

const SG::auxid_set_t & SG::AuxStoreInternal::getWritableAuxIDs ( ) const
overridevirtualinherited

Return a set of identifiers for writable data items in this store.

This should include only non-const identifiers.

Implements SG::IAuxStore.

Definition at line 433 of file AuxStoreInternal.cxx.

434 {
435  return getAuxIDs();
436 }

◆ insertMove()

bool SG::AuxStoreInternal::insertMove ( size_t  pos,
IAuxStore other,
const SG::auxid_set_t ignore = SG::auxid_set_t(0) 
)
overridevirtualinherited

Move all elements from other to this store.

Parameters
posThe starting index of the insertion.
otherStore from which to do the move.
ignoreSet of variables that should not be added to the store.

Let len be the size of other. The store will be increased in size by len elements, with the elements at pos being copied to pos+len. Then, for each auxiliary variable, the entire contents of that variable for other will be moved to this store at index pos. This will be done via move semantics if possible; otherwise, it will be done with a copy. Variables present in this store but not in other will have the corresponding elements default-initialized. Variables in other but not in this store will be added unless they are in ignore.

Returns true if it is known that none of the vectors' memory moved, false otherwise.

Implements SG::IAuxStore.

Definition at line 332 of file AuxStoreInternal.cxx.

335 {
336  guard_t guard (m_mutex);
337  const AuxTypeRegistry& r = AuxTypeRegistry::instance();
338 
339  if (m_locked)
340  throw ExcStoreLocked ("insertMove");
341  bool nomove = true;
342  size_t other_size = other.size();
343  if (other_size == 0)
344  return true;
345  for (SG::auxid_t id : m_auxids) {
346  SG::IAuxTypeVector* v_dst = nullptr;
347  if (id < m_vecs.size())
348  v_dst = m_vecs[id].get();
349  // Skip linked vars --- they should be taken care of by the parent var.
350  if (v_dst && !v_dst->isLinked()) {
351  if (other.getData (id)) {
352  void* src_ptr = other.getData (id, other_size, other_size);
353  if (src_ptr) {
354  if (!v_dst->insertMove (pos, src_ptr, 0, other_size,
355  other))
356  nomove = false;
357  }
358  }
359  else {
360  const void* orig = v_dst->toPtr();
361  v_dst->shift (pos, other_size);
362  if (orig != v_dst->toPtr())
363  nomove = false;
364  }
365  }
366  }
367 
368  // Add any new variables not present in the original container.
369  for (SG::auxid_t id : other.getAuxIDs()) {
370  if (!m_auxids.test(id) && !ignore.test(id))
371  {
372  if (r.isLinked (id)) continue;
373  if (other.getData (id)) {
374  void* src_ptr = other.getData (id, other_size, other_size);
375  if (src_ptr) {
376  size_t sz = size_noLock();
377  if (sz < other_size) sz = other_size + pos;
378  IAuxTypeVector* v = getVectorInternal_noLock (id, sz, sz, false);
379  v->resize (sz - other_size);
380  v->insertMove (pos, src_ptr, 0, other_size,
381  other);
382  nomove = false;
383  }
384  }
385  }
386  }
387 
388  return nomove;
389 }

◆ isDecoration()

bool RootAuxDynStore::isDecoration ( SG::auxid_t  auxid) const
overridevirtualinherited

Test if a particular variable is tagged as a decoration.

Parameters
auxidThe identifier of the desired aux data item.
auxidThe identifier of the desired aux data item.

See getDecoration() above.

Reimplemented from SG::AuxStoreInternal.

Definition at line 105 of file RootAuxDynStore.cxx.

106 {
107  guard_t guard( m_mutex );
108  if (SG::AuxStoreInternal::getIODataInternal (auxid, true) == 0 &&
110  {
111  return false;
112  }
113  return SG::AuxStoreInternal::isDecoration (auxid);
114 }

◆ linkedVector() [1/3]

const IAuxTypeVector * SG::AuxStoreInternal::linkedVector ( SG::auxid_t  auxid) const
overridevirtualinherited

Return interface for a linked variable.

Parameters
auxidThe ID of the parent variable.

If auxid has a linked variable, then return the IAuxTypeVector describing it. Otherwise, return nullptr. May return nullptr unconditionally if this store does not support linked variables.

Reimplemented from SG::IConstAuxStore.

Definition at line 789 of file AuxStoreInternal.cxx.

790 {
791  const AuxTypeRegistry& r = AuxTypeRegistry::instance();
792  auxid_t linked_id = r.linkedVariable (auxid);
793  guard_t guard (m_mutex);
794  if (linked_id < m_vecs.size())
795  return m_vecs[linked_id].get();
796  return nullptr;
797 }

◆ linkedVector() [2/3]

IAuxTypeVector * SG::AuxStoreInternal::linkedVector ( SG::auxid_t  auxid)
overridevirtualinherited

Return interface for a linked variable.

Parameters
auxidThe ID of the parent variable.

If auxid has a linked variable, then return the IAuxTypeVector describing it. Otherwise, return nullptr. May return nullptr unconditionally if this store does not support linked variables.

Reimplemented from SG::IAuxStore.

Definition at line 769 of file AuxStoreInternal.cxx.

770 {
771  const AuxTypeRegistry& r = AuxTypeRegistry::instance();
772  auxid_t linked_id = r.linkedVariable (auxid);
773  guard_t guard (m_mutex);
774  if (linked_id < m_vecs.size())
775  return m_vecs[linked_id].get();
776  return nullptr;
777 }

◆ linkedVector() [3/3]

virtual const IAuxTypeVector* SG::IConstAuxStore::linkedVector
inlineinherited

Return interface for a linked variable.

Parameters
auxidThe ID of the parent variable.

If auxid has a linked variable, then return the IAuxTypeVector describing it. Otherwise, return nullptr. May return nullptr unconditionally if this store does not support linked variables.

Definition at line 189 of file IConstAuxStore.h.

190  { return nullptr; }

◆ lock()

void SG::AuxStoreInternal::lock ( )
overridevirtualinherited

Lock the container.

After this, only decorations can be changed/modified. If the container is already locked, this is a no-op.

Implements SG::IConstAuxStore.

Definition at line 564 of file AuxStoreInternal.cxx.

565 {
566  guard_t guard (m_mutex);
567  m_locked = true;
568 }

◆ lockDecoration()

void SG::AuxStoreInternal::lockDecoration ( SG::auxid_t  auxid)
overridevirtualinherited

Lock a decoration.

Parameters
auxidIdentifier of the decoration to lock.

A decoration is locked by changing from a decoration to an ordinary variable. If the container itself is locked, then modifications to the variable are not permitted after this call.

Implements SG::IConstAuxStore.

Definition at line 753 of file AuxStoreInternal.cxx.

754 {
755  guard_t guard (m_mutex);
756  m_decorations.reset (auxid);
757 }

◆ readData()

bool TBranchAuxDynStore::readData ( SG::auxid_t  auxid)
finaloverrideprotectedvirtual

read data from ROOT and store it in m_vecs. Returns False on error

Implements RootAuxDynStore.

Definition at line 25 of file TBranchAuxDynStore.cxx.

26 {
27  try {
28  auto& brInfo = m_reader.getBranchInfo(auxid, *this);
29  if( !brInfo.branch ) return false;
30 
31  // Make a 1-element vector.
32  SG::AuxStoreInternal::getDataInternal(auxid, 1, 1, true);
33  if( brInfo.isPackedContainer ) {
34  setOption (auxid, SG::AuxDataOption ("nbits", 32));
35  }
36 
37  // get memory location where to write data from the branch entry
38  // const_cast because TTree::SetBranchAddress requires void*
39  void * vector ATLAS_THREAD_SAFE = const_cast<void*>(SG::AuxStoreInternal::getIOData (auxid));
40  void * data = &vector;
41  if( standalone() && !brInfo.tclass ) {
42  // reading fundamental type - ROOT expects a direct pointer
43  data = vector;
44  }
45 
46  // if have mutex, lock to prevent potential concurrent I/O from elsewhere
47  auto io_lock = m_iomutex? std::unique_lock<std::recursive_mutex>(*m_iomutex)
48  : std::unique_lock<std::recursive_mutex>();
49  // read branch
50  brInfo.setAddress(data);
51  int nbytes = brInfo.branch->GetEntry(m_entry);
52  if( nbytes <= 0 )
53  throw std::string("Error reading branch ") + brInfo.branch->GetName();
54  // read OK
55  m_reader.addBytes(nbytes);
56  TTree::TClusterIterator clusterIterator = brInfo.branch->GetTree()->GetClusterIterator(m_entry);
57  clusterIterator.Next();
58  if (m_entry == clusterIterator.GetStartEntry() && brInfo.branch->GetTree()->GetMaxVirtualSize() != 0) {
59  for (int i = brInfo.branch->GetReadBasket(); i < brInfo.branch->GetMaxBaskets()
60  && brInfo.branch->GetBasketEntry()[i] < clusterIterator.GetNextEntry(); i++) {
61  brInfo.branch->GetBasket(i);
62  }
63  }
64  }
65  catch(const std::string& e_str) {
66  ATHCONTAINERS_ERROR("TBranchAuxDynStore::getData", e_str);
67  return false;
68  }
69 
71  SG::auxid_t linked_auxid = r.linkedVariable (auxid);
72  if (linked_auxid != SG::null_auxid) {
73  return readData (linked_auxid);
74  }
75  return true;
76 }

◆ reserve()

void SG::AuxStoreInternal::reserve ( size_t  sz)
overridevirtualinherited

Change the capacity of all aux data vectors.

Parameters
szThe new capacity.

This should be called when the capacity of the container changes (by reserve). This should change the capacity for the vectors for all aux data items.

Implements SG::IAuxStore.

Definition at line 267 of file AuxStoreInternal.cxx.

268 {
269  guard_t guard (m_mutex);
270  if (m_locked)
271  throw ExcStoreLocked ("reserve");
272  for (std::unique_ptr<IAuxTypeVector>& v : m_vecs) {
273  if (v && !v->isLinked())
274  v->reserve (sz);
275  }
276 }

◆ resize()

bool SG::AuxStoreInternal::resize ( size_t  sz)
overridevirtualinherited

Change the size of all aux data vectors.

Parameters
szThe new size.

This should be called when the size of the container changes. This should resize the vectors for all aux data items.

If the size of the container grows, the new elements should be default-initialized; if it shrinks, destructors should be run as appropriate.

Should return true if it is known that none of the data pointers changed (and thus the cache does not need to be cleared), false otherwise.

Implements SG::IAuxStore.

Definition at line 243 of file AuxStoreInternal.cxx.

244 {
245  guard_t guard (m_mutex);
246  if (m_locked)
247  throw ExcStoreLocked ("resize");
248  bool nomoves = true;
249  for (std::unique_ptr<IAuxTypeVector>& v : m_vecs) {
250  if (v && !v->isLinked()) {
251  if (!v->resize (sz))
252  nomoves = false;
253  }
254  }
255  return nomoves;
256 }

◆ setOption()

bool SG::AuxStoreInternal::setOption ( auxid_t  id,
const AuxDataOption option 
)
overridevirtualinherited

Set an option for an auxiliary data variable.

Parameters
idThe variable for which we want to set the option.
optionThe option setting to make.

The interpretation of option depends on the associated auxiliary store. See PackedParameters.h for option settings for writing packed data. Returns true on success, false otherwise.

Reimplemented from SG::IAuxStore.

Definition at line 636 of file AuxStoreInternal.cxx.

637 {
638  // Does this variable exist in this store?
639  bool exists = false;
640  {
641  guard_t guard (m_mutex);
642  if (id < m_vecs.size() && m_vecs[id] != 0)
643  exists = true;
644  }
645 
646  // If not, and we have a packing parameter request, then create the variable.
647  if (!exists) {
648  if (!PackedParameters::isValidOption (option)) return false;
649  size_t sz = size();
650  getDataInternal (id, sz, sz, true);
651  }
652 
653  // Try the option setting.
654  guard_t guard (m_mutex);
655  if (m_vecs[id]->setOption (option)) return true;
656 
657  // It didn't work. If this is a packing request, then try to convert
658  // the variable to packed form and retry.
659  if (!PackedParameters::isValidOption (option)) return false;
660  std::unique_ptr<IAuxTypeVector> packed = m_vecs[id]->toPacked();
661  if (packed) {
662  // Converted to packed form. Replace the object and retry.
663  m_vecs[id] = std::move (packed);
664  return m_vecs[id]->setOption (option);
665  }
666 
667  // Didn't work.
668  return false;
669 }

◆ shift()

void SG::AuxStoreInternal::shift ( size_t  pos,
ptrdiff_t  offs 
)
overridevirtualinherited

Shift the elements of the container.

Parameters
posThe starting index for the shift.
offsThe (signed) amount of the shift.

This operation shifts the elements in the vectors for all aux data items, to implement an insertion or deletion. offs may be either positive or negative.

If offs is positive, then the container is growing. The container size should be increased by offs, the element at pos moved to pos + offs, and similarly for following elements. The elements between pos and pos + offs should be default-initialized.

If offs is negative, then the container is shrinking. The element at pos should be moved to pos + offs, and similarly for following elements. The container should then be shrunk by -offs elements (running destructors as appropriate).

Implements SG::IAuxStore.

Definition at line 301 of file AuxStoreInternal.cxx.

302 {
303  guard_t guard (m_mutex);
304  if (m_locked)
305  throw ExcStoreLocked ("shift");
306  for (std::unique_ptr<IAuxTypeVector>& v : m_vecs) {
307  if (v && !v->isLinked())
308  v->shift (pos, offs);
309  }
310 }

◆ size()

size_t RootAuxDynStore::size ( ) const
overridevirtualinherited

Return the number of elements in the store.

May return 0 for a store with no aux data.

NOTE: this method will attempt to read data if size unknown (0) May return 0 for a store with no aux data.

Reimplemented from SG::AuxStoreInternal.

Definition at line 121 of file RootAuxDynStore.cxx.

122 {
123  const std::size_t s = SG::AuxStoreInternal::size();
124  if( s != 0 ) {
125  return s;
126  }
127 
128  for( SG::auxid_t id : getAuxIDs() ) {
129  if( getData( id ) != nullptr ) {
131  }
132  }
133 
134  return 0;
135 }

◆ size_noLock()

size_t SG::AuxStoreInternal::size_noLock ( ) const
privateinherited

Return the number of elements in the store; no locking.

Return the number of elements in the store.

(No locking.)

May return 0 for a store with no aux data.

Definition at line 614 of file AuxStoreInternal.cxx.

615 {
616  for (SG::auxid_t id : m_auxids) {
617  if (id < m_vecs.size() && m_vecs[id] && !m_vecs[id]->isLinked() &&
618  m_vecs[id]->size() > 0)
619  {
620  return m_vecs[id]->size();
621  }
622  }
623  return 0;
624 }

◆ standalone()

bool SG::AuxStoreInternal::standalone ( ) const
inherited

Return the standalone flag.

Definition at line 67 of file AuxStoreInternal.cxx.

68 {
69  return m_standalone;
70 }

Member Data Documentation

◆ m_auxids

SG::auxid_set_t SG::AuxStoreInternal::m_auxids
privateinherited

Set of auxid's for which we've created a vector.

Definition at line 454 of file AuxStoreInternal.h.

◆ m_decorations

SG::auxid_set_t SG::AuxStoreInternal::m_decorations
privateinherited

Record which variables are decorations.

Definition at line 451 of file AuxStoreInternal.h.

◆ m_entry

long long RootAuxDynStore::m_entry
protectedinherited

Definition at line 62 of file RootAuxDynStore.h.

◆ m_iomutex

std::recursive_mutex* RootAuxDynStore::m_iomutex
protectedinherited

Optional mutex used to serialize I/O with RootStorageSvc (not owned)

Definition at line 70 of file RootAuxDynStore.h.

◆ m_locked

bool SG::AuxStoreInternal::m_locked
privateinherited

Has this container been locked?

Definition at line 457 of file AuxStoreInternal.h.

◆ m_mutex

mutex_t RootAuxDynStore::m_mutex
mutableprotectedinherited

Definition at line 67 of file RootAuxDynStore.h.

◆ m_reader

TBranchAuxDynReader& TBranchAuxDynStore::m_reader
protected

Definition at line 32 of file TBranchAuxDynStore.h.

◆ m_standalone

bool SG::AuxStoreInternal::m_standalone
privateinherited

Are we being written in standalone mode?

Definition at line 444 of file AuxStoreInternal.h.

◆ m_vecs

std::vector<std::unique_ptr<IAuxTypeVector> > SG::AuxStoreInternal::m_vecs
privateinherited

The collection of vectors of aux data that we're managing, indexed by auxid.

Definition at line 448 of file AuxStoreInternal.h.

◆ supportsThinning

constexpr bool SG::IAuxStore::supportsThinning = true
staticconstexprinherited

Mark that this type supports thinning operations.

See AthContainers/supportsThinning.h and AthenaPoolCnvSvc/T_AthenaPoolCnv.h. Helps guide which pool converter template will be used. If false, the default pool converter will be used rather than the aux store-specific one. Ordinary xAOD type should not touch this, but may be overridden in a derived class to handle certain special cases.

Definition at line 199 of file IAuxStore.h.


The documentation for this class was generated from the following files:
SG::IAuxTypeVector::shift
virtual bool shift(size_t pos, ptrdiff_t offs)=0
Shift the elements of the vector.
SG::IAuxTypeVector::isLinked
bool isLinked() const
Return true if this variable is linked from another one.
Definition: IAuxTypeVector.h:226
beamspotman.r
def r
Definition: beamspotman.py:676
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
SG::AuxStoreInternal::addAuxID
void addAuxID(auxid_t auxid)
Add a new auxid to the set of those being managed by this store.
Definition: AuxStoreInternal.cxx:676
RootAuxDynStore::m_mutex
mutex_t m_mutex
Definition: RootAuxDynStore.h:67
python.SystemOfUnits.s
int s
Definition: SystemOfUnits.py:131
fitman.sz
sz
Definition: fitman.py:527
SG::AuxStoreInternal::size_noLock
size_t size_noLock() const
Return the number of elements in the store; no locking.
Definition: AuxStoreInternal.cxx:614
SG::AuxStoreInternal::getDecoration
virtual void * getDecoration(auxid_t auxid, size_t size, size_t capacity) override
Return the data vector for one aux data decoration item.
Definition: AuxStoreInternal.cxx:198
PowhegControl_ttHplus_NLO.ss
ss
Definition: PowhegControl_ttHplus_NLO.py:83
SG::AuxTypeRegistry::instance
static AuxTypeRegistry & instance()
Return the singleton registry instance.
Definition: AuxTypeRegistry.cxx:639
SG::AuxStoreInternal::m_auxids
SG::auxid_set_t m_auxids
Set of auxid's for which we've created a vector.
Definition: AuxStoreInternal.h:454
quiet
bool quiet
Definition: TrigGlobEffCorrValidation.cxx:190
SG::AuxStoreInternal::guard_t
AthContainers_detail::lock_guard< mutex_t > guard_t
Definition: AuxStoreInternal.h:461
SG::AuxStoreInternal::m_mutex
mutex_t m_mutex
Definition: AuxStoreInternal.h:462
ATHCONTAINERS_ERROR
#define ATHCONTAINERS_ERROR(ctx, msg)
Definition: error.h:54
SG::AuxTypeRegistry::getName
std::string getName(SG::auxid_t auxid) const
Return the name of an aux data item.
Definition: AuxTypeRegistry.cxx:881
SG::AuxStoreInternal::standalone
bool standalone() const
Return the standalone flag.
Definition: AuxStoreInternal.cxx:67
SG::ExcStoreLocked
Exception — Attempted to modify auxiliary data in a locked store.
Definition: Control/AthContainers/AthContainers/exceptions.h:183
SG::AuxStoreInternal::m_decorations
SG::auxid_set_t m_decorations
Record which variables are decorations.
Definition: AuxStoreInternal.h:451
TBranchAuxDynStore::m_reader
TBranchAuxDynReader & m_reader
Definition: TBranchAuxDynStore.h:32
TBranchAuxDynStore::readData
virtual bool readData(SG::auxid_t auxid) override final
read data from ROOT and store it in m_vecs. Returns False on error
Definition: TBranchAuxDynStore.cxx:25
SG::IAuxTypeVector::insertMove
virtual bool insertMove(size_t pos, void *src, size_t src_pos, size_t src_n, IAuxStore &srcStore)=0
Insert elements into the vector via move semantics.
RootAuxDynStore::size
virtual size_t size() const override
Return the number of elements in the store.
Definition: RootAuxDynStore.cxx:121
vec
std::vector< size_t > vec
Definition: CombinationsGeneratorTest.cxx:12
SG::AuxStoreInternal::m_locked
bool m_locked
Has this container been locked?
Definition: AuxStoreInternal.h:457
CxxUtils::ConcurrentBitset::clear
ConcurrentBitset & clear()
Clear all bits in the set.
XMLtoHeader.count
count
Definition: XMLtoHeader.py:85
RootAuxDynStore
Definition: RootAuxDynStore.h:16
SG::AuxStoreInternal::getAuxIDs
virtual const SG::auxid_set_t & getAuxIDs() const override
Return a set of identifiers for existing data items in this store.
Definition: AuxStoreInternal.cxx:400
SG::AuxTypeRegistry
Handle mappings between names and auxid_t.
Definition: AuxTypeRegistry.h:61
DiTauMassTools::ignore
void ignore(T &&)
Definition: PhysicsAnalysis/TauID/DiTauMassTools/DiTauMassTools/HelperFunctions.h:58
SG::AuxStoreInternal::m_vecs
std::vector< std::unique_ptr< IAuxTypeVector > > m_vecs
The collection of vectors of aux data that we're managing, indexed by auxid.
Definition: AuxStoreInternal.h:448
SG::auxid_t
size_t auxid_t
Identifier for a particular aux data item.
Definition: AuxTypes.h:27
H5Utils::internal::packed
H5::CompType packed(H5::CompType in)
Definition: common.cxx:16
RootAuxDynStore::m_entry
long long m_entry
Definition: RootAuxDynStore.h:62
lumiFormat.i
int i
Definition: lumiFormat.py:85
CxxUtils::ConcurrentBitset::insert
ConcurrentBitset & insert(bit_t bit, bit_t new_nbits=0)
Set a bit to 1.
vector
Definition: MultiHisto.h:13
CxxUtils::ConcurrentBitset::reset
ConcurrentBitset & reset(bit_t bit)
Turn off one bit.
SG::AuxStoreInternal::getIODataInternal
const void * getIODataInternal(auxid_t auxid, bool quiet) const
Return a pointer to the data to be stored for one aux data item.
Definition: AuxStoreInternal.cxx:450
RootAuxDynStore::guard_t
AthContainers_detail::lock_guard< mutex_t > guard_t
Definition: RootAuxDynStore.h:66
lumiFormat.e_str
e_str
Definition: lumiFormat.py:81
RootAuxDynStore::getData
virtual const void * getData(SG::auxid_t auxid) const override
implementation of the IAuxStore interface
Definition: RootAuxDynStore.cxx:25
SG::AuxStoreInternal::getVectorInternal_noLock
virtual IAuxTypeVector * getVectorInternal_noLock(SG::auxid_t auxid, size_t size, size_t capacity, bool no_lock_check)
Implementation of getVectorInternal; no locking.
Definition: AuxStoreInternal.cxx:684
SG::AuxTypeRegistry::getVecType
const std::type_info * getVecType(SG::auxid_t auxid) const
Return the type of the STL vector used to hold an aux data item.
Definition: AuxTypeRegistry.cxx:936
SG::AuxStoreInternal::setOption
virtual bool setOption(auxid_t id, const AuxDataOption &option) override
Set an option for an auxiliary data variable.
Definition: AuxStoreInternal.cxx:636
SG::AuxStoreInternal::getDataInternal
virtual void * getDataInternal(SG::auxid_t auxid, size_t size, size_t capacity, bool no_lock_check)
Return the data vector for one aux data item.
Definition: AuxStoreInternal.cxx:735
SG::AuxStoreInternal::size
virtual size_t size() const override
Return the number of elements in the store.
Definition: AuxStoreInternal.cxx:602
TBranchAuxDynReader::addBytes
void addBytes(size_t bytes)
Definition: TBranchAuxDynReader.h:88
SG::IAuxStoreIO::getDynamicAuxIDs
virtual const SG::auxid_set_t & getDynamicAuxIDs() const =0
Get the list of all dynamically created variables.
SG::AuxStoreInternal::getIOData
virtual const void * getIOData(SG::auxid_t auxid) const override
Return a pointer to the data to be stored for one aux data item.
Definition: AuxStoreInternal.cxx:515
SG::AuxDataOption
Hold information about an option setting request.
Definition: AuxDataOption.h:37
GetAllXsec.entry
list entry
Definition: GetAllXsec.py:132
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:227
SG::PackedParameters::isValidOption
static bool isValidOption(const AuxDataOption &option)
Test to see if option is a recognized packing option.
Definition: PackedParameters.cxx:197
TBranchAuxDynReader::getBranchInfo
BranchInfo & getBranchInfo(const SG::auxid_t &auxid, const SG::AuxStoreInternal &store)
Definition: TBranchAuxDynReader.cxx:242
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:18
python.PyAthena.v
v
Definition: PyAthena.py:154
SG::AuxStoreInternal::m_standalone
bool m_standalone
Are we being written in standalone mode?
Definition: AuxStoreInternal.h:444
InDetDD::other
@ other
Definition: InDetDD_Defs.h:16
SG::AuxStoreInternal::getVector
virtual const IAuxTypeVector * getVector(SG::auxid_t auxid) const override
Return vector interface for one aux data item.
Definition: AuxStoreInternal.cxx:99
SG::AuxStoreInternal::isDecoration
virtual bool isDecoration(auxid_t auxid) const override
Test if a particular variable is tagged as a decoration.
Definition: AuxStoreInternal.cxx:420
SG::IAuxTypeVector
Abstract interface for manipulating vectors of arbitrary types.
Definition: IAuxTypeVector.h:42
RootAuxDynStore::getVector
virtual const SG::IAuxTypeVector * getVector(SG::auxid_t auxid) const override
Return vector interface for one aux data item.
Definition: RootAuxDynStore.cxx:35
ATLAS_THREAD_SAFE
#define ATLAS_THREAD_SAFE
Definition: checker_macros.h:211
python.dummyaccess.exists
def exists(filename)
Definition: dummyaccess.py:9
collisions.reader
reader
read the goodrunslist xml file(s)
Definition: collisions.py:22
CxxUtils::ConcurrentBitset::erase
ConcurrentBitset & erase(bit_t bit)
Turn off one bit.
RootAuxDynStore::RootAuxDynStore
RootAuxDynStore(RootAuxDynIO::IRootAuxDynReader &reader, long long entry, bool standalone, std::recursive_mutex *iomtx=nullptr)
Definition: RootAuxDynStore.cxx:12
RootAuxDynStore::m_iomutex
std::recursive_mutex * m_iomutex
Optional mutex used to serialize I/O with RootStorageSvc (not owned)
Definition: RootAuxDynStore.h:70
SG::IAuxTypeVector::toPtr
virtual void * toPtr()=0
Return a pointer to the start of the vector's data.
CxxUtils::ConcurrentBitset::test
bool test(bit_t bit) const
Test to see if a bit is set.