src/work/deba/vector_map_factory.h
author athos
Wed, 02 Jun 2004 09:45:50 +0000
changeset 672 6c7bd0edd1d7
parent 595 e10b5e9419ef
child 698 625de6f1e766
permissions -rw-r--r--
Seems to work. More tests required.
deba@571
     1
#ifndef VECTOR_MAP_H
deba@571
     2
#define VECTOR_MAP_H
deba@571
     3
deba@571
     4
#include <vector>
deba@571
     5
deba@627
     6
#include "map_registry.h"
deba@571
     7
deba@571
     8
namespace hugo {
deba@571
     9
	
deba@627
    10
  template <typename MapRegistry>
deba@627
    11
  class VectorMapFactory {
deba@627
    12
  public:
deba@627
    13
		
deba@627
    14
    typedef typename MapRegistry::Graph Graph;
deba@627
    15
    typedef typename MapRegistry::Key Key;
deba@627
    16
    typedef typename MapRegistry::KeyIt KeyIt;
deba@627
    17
deba@627
    18
    typedef typename MapRegistry::MapBase MapBase;
deba@627
    19
		
deba@627
    20
    template <typename V> 
deba@627
    21
      class Map : public MapBase {
deba@627
    22
      public:
deba@627
    23
      typedef V Value;
deba@571
    24
	
deba@627
    25
      Map() {}
deba@627
    26
			
deba@627
    27
      Map(Graph& g, MapRegistry& r) : MapBase(g, r) {
deba@627
    28
	init();
deba@627
    29
      }
deba@627
    30
			
deba@627
    31
						
deba@627
    32
      virtual ~Map() {
deba@627
    33
	destroy();
deba@627
    34
      }
deba@571
    35
	
deba@627
    36
	
deba@627
    37
      Value& operator[](const Key& key) {
deba@627
    38
	int id = graph->id(key);
deba@627
    39
	return container[id];
deba@627
    40
      } 
deba@571
    41
		
deba@627
    42
      const Value& operator[](const Key& key) const {
deba@627
    43
	int id = graph->id(key);
deba@627
    44
	return container[id];
deba@627
    45
      }
deba@627
    46
	
deba@627
    47
      const Value& get(const Key& key) const {
deba@627
    48
	int id = graph->id(key);
deba@627
    49
	return container[id];
deba@627
    50
      } 
deba@571
    51
		
deba@627
    52
      void set(const Key& key, const Value& val) {
deba@627
    53
	int id = graph->id(key);
deba@627
    54
	container[id] = val;
deba@627
    55
      }
deba@627
    56
		
deba@627
    57
      void add(const Key& key) {
deba@627
    58
	int id = graph->id(key);
deba@627
    59
	if (id >= container.size()) {
deba@627
    60
	  container.resize(id + 1);
deba@627
    61
	}
deba@627
    62
      }
deba@627
    63
		
deba@627
    64
      void erase(const Key& key) {}
deba@571
    65
	
deba@627
    66
      private:
deba@627
    67
      typedef std::vector<Value> Container;
deba@571
    68
		
deba@627
    69
      Container container;
deba@627
    70
    };
deba@571
    71
		
deba@627
    72
  };
deba@571
    73
}
deba@571
    74
deba@571
    75
#endif