Belle II Software  release-08-01-10
RelationIndexManager Class Reference

Manager to keep a cache of existing RelationIndexContainers. More...

#include <RelationIndexManager.h>

Collaboration diagram for RelationIndexManager:

Public Member Functions

template<class FROM , class TO >
std::shared_ptr< RelationIndexContainer< FROM, TO > > get (const RelationArray &relation)
 Get a RelationIndexContainer. More...
 
void clear (DataStore::EDurability durability=DataStore::c_Event)
 Clear the cache of RelationIndexContainers with the given durability. More...
 
void reset ()
 Reset the cache completely, that is clear all caches and don't even keep the Index objects around. More...
 

Static Public Member Functions

static RelationIndexManagerInstance ()
 Returns the singleton instance.
 

Protected Types

typedef std::map< std::string, std::shared_ptr< RelationIndexBase > > RelationMap
 Maptype to keep track of all Containers of one durability.
 
typedef std::array< RelationMap, DataStore::c_NDurabilityTypesRelationCache
 Cachetype for all Containers.
 

Protected Member Functions

 RelationIndexManager ()=default
 No Constructor hidden.
 
 RelationIndexManager (const RelationIndexManager &)=delete
 No copy-constructor.
 
 RelationIndexManager (RelationIndexManager &&)=delete
 No move constructor.
 
RelationIndexManageroperator= (const RelationIndexManager &)=delete
 Also no assignment.
 
template<class FROM , class TO >
std::shared_ptr< RelationIndexContainer< FROM, TO > > getIndexIfExists (const std::string &name, DataStore::EDurability durability) const
 if the index exists in the cache, it is returned; otherwise NULL. More...
 
 ~RelationIndexManager ()
 Clean cache on exit.
 

Protected Attributes

RelationCache m_cache
 Cache for all Containers.
 

Friends

class DataStore
 only DataStore should be able to get non-const indices.
 

Detailed Description

Manager to keep a cache of existing RelationIndexContainers.

This singleton keeps track of all RelationIndexContainers that where created to make sure indices are not created more often than needed.

This class is only used internally, users should use RelationsObject/RelationsInterface to access/add relations.

Definition at line 30 of file RelationIndexManager.h.

Member Function Documentation

◆ clear()

void clear ( DataStore::EDurability  durability = DataStore::c_Event)

Clear the cache of RelationIndexContainers with the given durability.

Parameters
durabilityWhich cache to clear

Definition at line 18 of file RelationIndexManager.cc.

19 {
20  RelationMap& relations = m_cache[durability];
21  for (auto& e : relations) {
22  if (e.second) e.second->clear();
23  }
24 }
RelationCache m_cache
Cache for all Containers.
std::map< std::string, std::shared_ptr< RelationIndexBase > > RelationMap
Maptype to keep track of all Containers of one durability.

◆ get()

std::shared_ptr<RelationIndexContainer<FROM, TO> > get ( const RelationArray relation)
inline

Get a RelationIndexContainer.

Return a const reference to a RelationIndexContainer for the given name and durability. If none exists it will be created. If it already exists we rebuild the index if the underlying RelationArray has changed in the meantime

Parameters
relationRelation to build an index for
Returns
A RelationIndexContainer

Definition at line 45 of file RelationIndexManager.h.

46  {
47  const static bool doTypeCheck = (FROM::Class() != TObject::Class() or TO::Class() != TObject::Class());
48  if (doTypeCheck)
49  relation.isValid();
50 
51  const std::string& name = relation.getName();
52  DataStore::EDurability durability = relation.getDurability();
53  RelationMap& relations = m_cache[durability];
54  std::shared_ptr<RelationIndexContainer<FROM, TO>> indexContainer;
55  RelationMap::iterator it = relations.find(name);
56  if (it != relations.end()) {
57  //if existing array is of wrong type, we'll overwrite the shared_ptr here, but the index will live on with any RelationIndex objects that use it.
58  indexContainer = std::dynamic_pointer_cast<RelationIndexContainer<FROM, TO>>(it->second);
59  }
60  if (!indexContainer) {
61  indexContainer.reset(new RelationIndexContainer<FROM, TO>(relation));
62  relations[name] = indexContainer;
63  } else {
64  indexContainer->rebuild(false);
65  }
66  return indexContainer;
67  }
friend class DataStore
only DataStore should be able to get non-const indices.

◆ getIndexIfExists()

std::shared_ptr<RelationIndexContainer<FROM, TO> > getIndexIfExists ( const std::string &  name,
DataStore::EDurability  durability 
) const
inlineprotected

if the index exists in the cache, it is returned; otherwise NULL.

The index is not rebuilt, which makes this mostly useful to do minor changes to the index in DataStore::addRelation().

Definition at line 101 of file RelationIndexManager.h.

◆ reset()

void reset ( void  )
inline

Reset the cache completely, that is clear all caches and don't even keep the Index objects around.

Needed when the DataStore is reset to make sure we don't have dangling pointer into the previous DataStore contents.

Definition at line 81 of file RelationIndexManager.h.


The documentation for this class was generated from the following files: