summaryrefslogtreecommitdiff
path: root/src/maps/hashmap.tmpl
blob: 9ee2f36b8e42cc178231b0cb0ef691e408716cda (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
template<class key_type_>
bool
compare_allocator<key_type_>::operator()(key_type_ t_key_1, key_type_ t_key_2) const
{
  return t_key_1.compare(t_key_2) == 0;
}

template<class key_type_>
bool
equals_allocator<key_type_>::operator()(key_type_ t_key_1, key_type_ t_key_2) const
{
  return t_key_1 == t_key_2;
}

template<class key_type_>
int
size_hash<key_type_>::operator()(key_type_ t_key) const
{
  int i_hash = 0;
  int i_size = t_key.size();

  for( size_t i = 0; i < i_size; ++i )
    i_hash =  ( i_hash << 5 ) ^ t_key.at(i) ^ i_hash;

  return i_hash;
}

template<class key_type_>
int
self_hash<key_type_>::operator()(key_type_ t_key) const
{
  return t_key;
}


template<class obj_type, class key_type_, class hash_type, class alloc_type>
obj_type
hashmap<obj_type, key_type_, hash_type, alloc_type>::get_set_elem(obj_type t_obj, key_type_ t_key)
{
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter = this->find(t_key);

  if ( iter == this->end() )
  {
    set_elem(t_obj, t_key);
    return obj_type();
  }

  obj_type t_ret = iter->second;
  iter->second = t_obj;

  return t_ret;
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
obj_type
hashmap<obj_type, key_type_, hash_type, alloc_type>::get_or_callback_set
(obj_type (*func)(void*), void* p_void, key_type_ t_key)
{
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter = this->find(t_key);

  if ( iter == this->end() )
  {
    obj_type t_obj = (*func) (p_void);
    set_elem(t_obj, t_key);
    return t_obj;
  }

  return iter->second;
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
void
hashmap<obj_type, key_type_, hash_type, alloc_type>::set_elem(obj_type t_obj, key_type_ t_key)
{
  (*this)[t_key] = t_obj;
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
obj_type
hashmap<obj_type, key_type_, hash_type, alloc_type>::get_elem(key_type_ t_key)
{
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter = this->find(t_key);

  if ( iter != this->end() )
    return iter->second;

  return obj_type();
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
vector<key_type_>*
hashmap<obj_type, key_type_, hash_type, alloc_type>::get_key_vector()
{
  vector<key_type_>* p_vec = new vector<key_type_>;
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter;

  for ( iter = this->begin(); iter != this->end(); ++iter )
    p_vec->push_back(iter->first);

  return p_vec;
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
bool
hashmap<obj_type, key_type_, hash_type, alloc_type>::exists(key_type_ t_key)
{
  return this->find(t_key) != this->end();
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
void
hashmap<obj_type, key_type_, hash_type, alloc_type>::run_func( void (*func)(obj_type) )
{
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter;
  for ( iter = this->begin(); iter != this->end(); ++iter )
    ( *func ) ( iter->second );
}

template<class obj_type, class key_type_, class hash_type, class alloc_type>
void
hashmap<obj_type, key_type_, hash_type, alloc_type>::run_func( void (*func)(obj_type, void*), void* v_arg )
{
  typename hashmap<obj_type, key_type_, hash_type, alloc_type>::iterator iter;
  for ( iter = this->begin(); iter != this->end(); ++iter )
    ( *func ) ( iter->second, v_arg );
}