| [a80f419] | 1 | /* | 
|---|
|  | 2 | * AtomSet.hpp | 
|---|
|  | 3 | * | 
|---|
|  | 4 | *  Created on: Jul 8, 2010 | 
|---|
|  | 5 | *      Author: crueger | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #ifndef OBSERVEDCONTAINER_HPP_ | 
|---|
|  | 9 | #define OBSERVEDCONTAINER_HPP_ | 
|---|
|  | 10 |  | 
|---|
| [70672e3] | 11 | // include config.h | 
|---|
|  | 12 | #ifdef HAVE_CONFIG_H | 
|---|
|  | 13 | #include <config.h> | 
|---|
|  | 14 | #endif | 
|---|
|  | 15 |  | 
|---|
| [9e619e] | 16 | #include <iterator> | 
|---|
| [a80f419] | 17 | #include <utility> | 
|---|
| [9e619e] | 18 |  | 
|---|
| [9b8fa4] | 19 | #include "CodePatterns/Observer/ObservedIterator.hpp" | 
|---|
| [9e619e] | 20 | #include "CodePatterns/Observer/UnobservedIterator.hpp" | 
|---|
| [a80f419] | 21 |  | 
|---|
|  | 22 | /** | 
|---|
|  | 23 | * Forward to std::map<atomId_t,atom*> that allows production of observed and | 
|---|
|  | 24 | * unobserved iterators to all atoms. | 
|---|
|  | 25 | * | 
|---|
|  | 26 | * Imported via typedef into class World. Defined here to avoid bloating of the | 
|---|
|  | 27 | * World class | 
|---|
|  | 28 | */ | 
|---|
| [9e619e] | 29 | template <class Container, class Iterator = ObservedIterator<Container> > | 
|---|
| [a80f419] | 30 | class ObservedContainer | 
|---|
|  | 31 | { | 
|---|
|  | 32 | public: | 
|---|
|  | 33 | typedef Container set_t; | 
|---|
|  | 34 | // this iterator can be used for internal purposes... | 
|---|
|  | 35 | // no lock used here | 
|---|
|  | 36 | typedef typename set_t::iterator                              internal_iterator; | 
|---|
|  | 37 | typedef typename std::reverse_iterator<internal_iterator>     reverse_internal_iterator; | 
|---|
|  | 38 |  | 
|---|
| [9e619e] | 39 | typedef Iterator iterator; | 
|---|
| [a80f419] | 40 | // typedefs for iterator structure | 
|---|
|  | 41 | typedef typename set_t::const_iterator                        const_iterator; | 
|---|
| [d3926b5] | 42 | typedef typename std::reverse_iterator<iterator>              reverse_iterator; | 
|---|
| [a80f419] | 43 | typedef typename std::reverse_iterator<const_iterator>        const_reverse_iterator; | 
|---|
|  | 44 |  | 
|---|
|  | 45 | // some more typedefs for STL-Structure | 
|---|
|  | 46 | typedef typename set_t::key_type               key_type; | 
|---|
|  | 47 | typedef typename set_t::mapped_type            mapped_type; | 
|---|
|  | 48 | typedef typename set_t::value_type             value_type; | 
|---|
|  | 49 | typedef typename set_t::key_compare            key_compare; | 
|---|
|  | 50 | typedef typename set_t::allocator_type         allocator_type; | 
|---|
|  | 51 |  | 
|---|
|  | 52 | ObservedContainer(Observable*); | 
|---|
|  | 53 | ObservedContainer(const ObservedContainer&); | 
|---|
|  | 54 | virtual ~ObservedContainer(); | 
|---|
|  | 55 |  | 
|---|
|  | 56 | // all the functions from STL-map (forwards to content) | 
|---|
|  | 57 | ObservedContainer& operator=(const ObservedContainer&); | 
|---|
|  | 58 |  | 
|---|
|  | 59 | iterator                      begin(); | 
|---|
|  | 60 | const_iterator                begin()         const; | 
|---|
|  | 61 | iterator                      end(); | 
|---|
|  | 62 | const_iterator                end()           const; | 
|---|
|  | 63 | reverse_iterator              rbegin(); | 
|---|
|  | 64 | const_reverse_iterator        rbegin()        const; | 
|---|
|  | 65 | reverse_iterator              rend(); | 
|---|
|  | 66 | const_reverse_iterator        rend()          const; | 
|---|
|  | 67 |  | 
|---|
|  | 68 | bool empty() const; | 
|---|
|  | 69 | size_t size() const; | 
|---|
|  | 70 | size_t max_size() const; | 
|---|
|  | 71 |  | 
|---|
|  | 72 | mapped_type &operator[](const key_type&); | 
|---|
|  | 73 |  | 
|---|
|  | 74 | std::pair<iterator,bool> insert (const value_type&); | 
|---|
|  | 75 |  | 
|---|
|  | 76 | size_t erase ( const key_type& x ); | 
|---|
|  | 77 | void clear(); | 
|---|
|  | 78 |  | 
|---|
|  | 79 | iterator              find ( const key_type& x ); | 
|---|
|  | 80 | const_iterator        find ( const key_type& x ) const; | 
|---|
|  | 81 |  | 
|---|
|  | 82 | size_t count ( const key_type& x ) const; | 
|---|
|  | 83 | internal_iterator             begin_internal(); | 
|---|
|  | 84 | internal_iterator             end_internal(); | 
|---|
|  | 85 | reverse_internal_iterator     rbegin_internal(); | 
|---|
|  | 86 | reverse_internal_iterator     rend_internal(); | 
|---|
|  | 87 |  | 
|---|
|  | 88 | set_t &getContent(); | 
|---|
|  | 89 | private: | 
|---|
|  | 90 | set_t content; | 
|---|
|  | 91 | Observable *obs; | 
|---|
|  | 92 | }; | 
|---|
|  | 93 |  | 
|---|
|  | 94 | #endif /* OBSERVEDCONTAINER_HPP_ */ | 
|---|