source: src/Patterns/Registry_impl.hpp@ a80f419

Last change on this file since a80f419 was a80f419, checked in by Frederik Heber <heber@…>, 15 years ago

First version.

Everything was extracted from project MoleCuilder and adapted such that it
runs on its own (i.e. new configure.ac, Makefile.am structure, stuff for
libtool versioning, ...)

  • Property mode set to 100644
File size: 4.9 KB
RevLine 
[a80f419]1/*
2 * Registry_impl.hpp
3 *
4 * Created on: Jul 28, 2010
5 * Author: heber
6 */
7
8#ifndef REGISTRY_IMPL_HPP_
9#define REGISTRY_IMPL_HPP_
10
11#include "MemDebug.hpp"
12
13#include "Patterns/Registry.hpp"
14#include "Patterns/Singleton_impl.hpp"
15
16#include "Assert.hpp"
17#include <iostream>
18
19/** Constructor for class Registry.
20 */
21template <class T> Registry<T>::Registry()
22{}
23
24/** Destructor for class Registry.
25 */
26template <class T> Registry<T>::~Registry()
27{}
28
29/** Returns pointer to an instance named by \a name.
30 * \param name name of instance
31 * \return pointer to instance
32 */
33template <class T> T* Registry<T>::getByName(const std::string name) const
34{
35 typename std::map<const std::string,T*>::const_iterator iter;
36 iter = InstanceMap.find(name);
37 ASSERT(iter!=InstanceMap.end(),"Query for an instance "+name+" not stored in registry");
38 return iter->second;
39}
40
41/** States whether instance is present or not.
42 * \note This is needed as Registry<T>::getByName() ASSERT()s that instance is in std::map.
43 * \param name name of instance
44 * \return true - present, false - instance absent
45 */
46template <class T>bool Registry<T>::isPresentByName(const std::string name) const
47{
48 typename std::map<const std::string,T*>::const_iterator iter;
49 iter = InstanceMap.find(name);
50 return iter!=InstanceMap.end();
51}
52
53/** Registers an instance with the Registry.
54 * \param *instance pointer to T.
55 */
56template <class T>void Registry<T>::registerInstance(T* instance){
57 std::pair<typename std::map<const std::string,T*>::iterator,bool> ret;
58 //std::cout << "Trying to register instance of type " << typeid(T).name() << " with name " << instance->getName() << "." << std::endl;
59 ret = InstanceMap.insert(typename std::pair<const std::string,T*>(instance->getName(),instance));
60 ASSERT(ret.second,"Two instances with the same name "+instance->getName()+" added to registry");
61}
62
63/** Unregisters an instance.
64 * \param *instance pointer to instance.
65 */
66template <class T>void Registry<T>::unregisterInstance(T* instance){
67 //std::cout << "Unregistering instance of type " << typeid(T).name() << " with name " << instance->getName() << "." << std::endl;
68 InstanceMap.erase(instance->getName());
69}
70
71/** Removes every instance from the registry.
72 */
73template <class T>void Registry<T>::cleanup()
74{
75 typename std::map<const std::string,T*>::iterator iter;
76 for(iter=InstanceMap.begin();iter!=InstanceMap.end();++iter) {
77 //std::cerr << "Removing instance "+iter->first+" from registry" << std::endl;
78 delete iter->second;
79 }
80 InstanceMap.clear();
81}
82
83
84/** Returns an iterator pointing to the start of the std::map of instance's.
85 * \return begin iterator
86 */
87template <class T>
88typename std::map<const std::string,T*>::iterator Registry<T>::getBeginIter()
89{
90 return InstanceMap.begin();
91}
92
93/** Returns an iterator pointing to the end of the std::map of instance's.
94 * \return end iterator
95 */
96template <class T>
97typename std::map<const std::string,T*>::iterator Registry<T>::getEndIter()
98{
99 return InstanceMap.end();
100}
101
102/** Returns a const iterator pointing to the start of the std::map of instance's.
103 * \return constant begin iterator
104 */
105template <class T>
106typename std::map<const std::string,T*>::const_iterator Registry<T>::getBeginIter() const
107{
108 return InstanceMap.begin();
109}
110
111/** Returns a const iterator pointing to the end of the std::map of instance's.
112 * \return constant end iterator
113 */
114template <class T>
115typename std::map<const std::string,T*>::const_iterator Registry<T>::getEndIter() const
116{
117 return InstanceMap.end();
118}
119
120/** Prints the contents of the Registry \a &m to \a &ost.
121 * \param &ost output stream
122 * \param &m reference to Registry
123 * \return reference to the above out stream for concatenation
124 */
125template <class T>
126std::ostream& operator<<(std::ostream& ost, const Registry<T>& m)
127{
128 ost << "Registry contains:" << std::endl;
129 for (typename std::map<const std::string,T*>::const_iterator iter = m.getBeginIter(); iter != m.getEndIter(); ++iter) {
130 ost << "\t" << iter->first << " with pointer " << iter->second << std::endl;
131 }
132 return ost;
133};
134
135/**
136 * This define allows simple instantiation of the necessary registryfunctions
137 * at a chosen place.
138 */
139#define CONSTRUCT_REGISTRY(InstanceType) \
140 template InstanceType* Registry<InstanceType>::getByName(const std::string) const; \
141 template bool Registry<InstanceType>::isPresentByName(const std::string) const; \
142 template void Registry<InstanceType>::registerInstance(InstanceType*); \
143 template void Registry<InstanceType>::unregisterInstance(InstanceType*); \
144 template std::map<const std::string,InstanceType*>::iterator Registry<InstanceType>::getBeginIter(); \
145 template std::map<const std::string,InstanceType*>::const_iterator Registry<InstanceType>::getBeginIter() const; \
146 template std::map<const std::string,InstanceType*>::iterator Registry<InstanceType>::getEndIter(); \
147 template std::map<const std::string,InstanceType*>::const_iterator Registry<InstanceType>::getEndIter() const;
148
149
150#endif /* REGISTRY_IMPL_HPP_ */
Note: See TracBrowser for help on using the repository browser.