src/work/deba/map_registry.h
author alpar
Sun, 09 May 2004 16:22:49 +0000
changeset 591 eb532eef6170
parent 378 c3f93631cd24
child 595 e10b5e9419ef
permissions -rw-r--r--
FullGraph class.
deba@378
     1
#ifndef MAP_REGISTRY_H
deba@378
     2
#define MAP_REGISTRY_H
deba@378
     3
deba@378
     4
#include <vector>
deba@378
     5
deba@378
     6
deba@378
     7
namespace hugo {
deba@378
     8
	template <typename G, typename K, typename KIt>
deba@378
     9
	class MapRegistry;
deba@378
    10
}
deba@378
    11
deba@378
    12
#include "map_base.h"
deba@378
    13
deba@378
    14
namespace hugo {
deba@378
    15
deba@378
    16
	template <typename G, typename K, typename KIt>
deba@378
    17
	class MapRegistry {
deba@378
    18
	public:
deba@378
    19
		typedef G Graph;
deba@378
    20
		typedef K Key;
deba@378
    21
		typedef KIt KeyIt;
deba@378
    22
	
deba@378
    23
		typedef MapBase<Graph, Key, KIt> Map;
deba@378
    24
		friend class Base;
deba@378
    25
	
deba@378
    26
	protected:
deba@378
    27
	
deba@378
    28
		typedef std::vector<Map*> Container; 
deba@378
    29
	  Container container;
deba@378
    30
deba@378
    31
		
deba@378
    32
	public:
deba@378
    33
	
deba@571
    34
		MapRegistry() {}
deba@571
    35
	
deba@571
    36
		MapRegistry(const MapRegistry&) {}
deba@571
    37
		
deba@571
    38
		MapRegistry& operator=(const MapRegistry&) {
deba@571
    39
			for (it = container.begin(); it != container.end(); ++it) {
deba@571
    40
				(*it)->destroy();
deba@571
    41
				(*it)->graph = 0;
deba@571
    42
				(*it)->registry = 0;
deba@571
    43
			}
deba@571
    44
		}
deba@378
    45
				
deba@378
    46
		~MapRegistry() {
deba@378
    47
			typename Container::iterator it;
deba@378
    48
			for (it = container.begin(); it != container.end(); ++it) {
deba@571
    49
				(*it)->destroy();
deba@378
    50
				(*it)->registry = 0;
deba@571
    51
				(*it)->graph = 0;
deba@378
    52
			}
deba@378
    53
		}
deba@378
    54
	
deba@378
    55
	
deba@378
    56
	public:
deba@378
    57
	
deba@571
    58
		void attach(Map& map) {
deba@378
    59
			if (map.registry) {
deba@571
    60
				map.registry->detach(map);
deba@378
    61
			}
deba@378
    62
			container.push_back(&map);
deba@378
    63
			map.registry = this;
deba@378
    64
			map.registry_index = container.size()-1;
deba@571
    65
			map.init();
deba@378
    66
		} 
deba@378
    67
	
deba@571
    68
		void detach(Map& map_base) {
deba@571
    69
			map_base.destroy();
deba@378
    70
			container.back()->registry_index = map_base.registry_index; 
deba@378
    71
			container[map_base.registry_index] = container.back();
deba@378
    72
			container.pop_back();
deba@378
    73
			map_base.registry = 0;
deba@571
    74
			map_base.graph = 0;
deba@378
    75
		}
deba@378
    76
	
deba@378
    77
		
deba@378
    78
		void add(Key& key) {
deba@378
    79
			typename Container::iterator it;
deba@378
    80
			for (it = container.begin(); it != container.end(); ++it) {
deba@378
    81
				(*it)->add(key);
deba@378
    82
			}
deba@378
    83
		}	
deba@378
    84
		
deba@378
    85
		void erase(Key& key) {
deba@378
    86
			typename Container::iterator it;
deba@378
    87
			for (it = container.begin(); it != container.end(); ++it) {
deba@378
    88
				(*it)->erase(key);
deba@378
    89
			}
deba@378
    90
		}
deba@378
    91
deba@378
    92
	};
deba@378
    93
deba@378
    94
}
deba@378
    95
deba@378
    96
#endif