]> git.saurik.com Git - wxWidgets.git/blame - src/common/hash.cpp
Now wxGIFDecoder always tries to read to the end of the GIF data.
[wxWidgets.git] / src / common / hash.cpp
CommitLineData
c801d85f
KB
1/////////////////////////////////////////////////////////////////////////////
2// Name: hash.cpp
3// Purpose: wxHashTable implementation
4// Author: Julian Smart
5// Modified by:
6// Created: 01/02/97
7// RCS-ID: $Id$
8// Copyright: (c) Julian Smart and Markus Holzem
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifdef __GNUG__
13#pragma implementation "hash.h"
14#endif
15
16// For compilers that support precompilation, includes "wx.h".
17#include "wx/wxprec.h"
18
19#ifdef __BORLANDC__
20#pragma hdrstop
21#endif
22
23#ifndef WX_PRECOMP
24#include "wx/list.h"
25#endif
26
27#include "wx/hash.h"
28
29#include <string.h>
30#include <stdarg.h>
31
c801d85f 32IMPLEMENT_DYNAMIC_CLASS(wxHashTable, wxObject)
c801d85f 33
debe6624 34wxHashTable::wxHashTable (int the_key_type, int size)
c801d85f 35{
17d8ee1c
JS
36 n = 0;
37 hash_table = (wxList**) NULL;
38 Create(the_key_type, size);
5692876f 39 m_count = 0;
c7fb814a 40 m_deleteContents = FALSE;
17d8ee1c 41/*
c801d85f
KB
42 n = size;
43 current_position = -1;
c67daf87 44 current_node = (wxNode *) NULL;
c801d85f
KB
45
46 key_type = the_key_type;
47 hash_table = new wxList *[size];
48 int i;
49 for (i = 0; i < size; i++)
c67daf87 50 hash_table[i] = (wxList *) NULL;
17d8ee1c 51*/
c801d85f
KB
52}
53
54wxHashTable::~wxHashTable (void)
55{
e55ad60e
RR
56 Destroy();
57}
58
59void wxHashTable::Destroy(void)
60{
61 if (!hash_table) return;
c801d85f
KB
62 int i;
63 for (i = 0; i < n; i++)
64 if (hash_table[i])
65 delete hash_table[i];
66 delete[] hash_table;
e55ad60e 67 hash_table = NULL;
c801d85f
KB
68}
69
debe6624 70bool wxHashTable::Create(int the_key_type, int size)
c801d85f 71{
17d8ee1c
JS
72 Destroy();
73
c801d85f
KB
74 n = size;
75 current_position = -1;
c67daf87 76 current_node = (wxNode *) NULL;
c801d85f
KB
77
78 key_type = the_key_type;
c801d85f
KB
79 hash_table = new wxList *[size];
80 int i;
81 for (i = 0; i < size; i++)
c67daf87 82 hash_table[i] = (wxList *) NULL;
c801d85f
KB
83 return TRUE;
84}
85
4e67bfc7
VS
86
87void wxHashTable::DoCopy(const wxHashTable& table)
88{
89 n = table.n;
90 current_position = table.current_position;
91 current_node = NULL; // doesn't matter - Next() will reconstruct it
92 key_type = table.key_type;
93
94 hash_table = new wxList *[n];
95 for (int i = 0; i < n; i++) {
96 if (table.hash_table[i] == NULL)
97 hash_table[i] = NULL;
98 else {
99 hash_table[i] = new wxList(key_type);
100 *(hash_table[i]) = *(table.hash_table[i]);
101 }
102 }
103}
104
debe6624 105void wxHashTable::Put (long key, long value, wxObject * object)
c801d85f
KB
106{
107 // Should NEVER be
108 long k = (long) key;
109 if (k < 0)
110 k = -k;
111
112 int position = (int) (k % n);
113 if (!hash_table[position])
c7fb814a 114 {
c801d85f 115 hash_table[position] = new wxList (wxKEY_INTEGER);
c7fb814a
VS
116 if (m_deleteContents) hash_table[position]->DeleteContents(TRUE);
117 }
c801d85f
KB
118
119 hash_table[position]->Append (value, object);
5692876f 120 m_count++;
c801d85f
KB
121}
122
50920146 123void wxHashTable::Put (long key, const wxChar *value, wxObject * object)
c801d85f
KB
124{
125 // Should NEVER be
126 long k = (long) key;
127 if (k < 0)
128 k = -k;
129
130 int position = (int) (k % n);
131 if (!hash_table[position])
c7fb814a 132 {
c801d85f 133 hash_table[position] = new wxList (wxKEY_INTEGER);
c7fb814a
VS
134 if (m_deleteContents) hash_table[position]->DeleteContents(TRUE);
135 }
c801d85f
KB
136
137 hash_table[position]->Append (value, object);
5692876f 138 m_count++;
c801d85f
KB
139}
140
debe6624 141void wxHashTable::Put (long key, wxObject * object)
c801d85f
KB
142{
143 // Should NEVER be
144 long k = (long) key;
145 if (k < 0)
146 k = -k;
147
148 int position = (int) (k % n);
149 if (!hash_table[position])
c7fb814a 150 {
c801d85f 151 hash_table[position] = new wxList (wxKEY_INTEGER);
c7fb814a
VS
152 if (m_deleteContents) hash_table[position]->DeleteContents(TRUE);
153 }
154
c801d85f 155 hash_table[position]->Append (k, object);
5692876f 156 m_count++;
c801d85f
KB
157}
158
50920146 159void wxHashTable::Put (const wxChar *key, wxObject * object)
c801d85f
KB
160{
161 int position = (int) (MakeKey (key) % n);
162
163 if (!hash_table[position])
c7fb814a 164 {
c801d85f 165 hash_table[position] = new wxList (wxKEY_STRING);
c7fb814a
VS
166 if (m_deleteContents) hash_table[position]->DeleteContents(TRUE);
167 }
c801d85f
KB
168
169 hash_table[position]->Append (key, object);
5692876f 170 m_count++;
c801d85f
KB
171}
172
debe6624 173wxObject *wxHashTable::Get (long key, long value) const
c801d85f
KB
174{
175 // Should NEVER be
176 long k = (long) key;
177 if (k < 0)
178 k = -k;
179
180 int position = (int) (k % n);
181 if (!hash_table[position])
c67daf87 182 return (wxObject *) NULL;
c801d85f
KB
183 else
184 {
185 wxNode *node = hash_table[position]->Find (value);
186 if (node)
187 return node->Data ();
188 else
c67daf87 189 return (wxObject *) NULL;
c801d85f
KB
190 }
191}
192
50920146 193wxObject *wxHashTable::Get (long key, const wxChar *value) const
c801d85f
KB
194{
195 // Should NEVER be
196 long k = (long) key;
197 if (k < 0)
198 k = -k;
199
200 int position = (int) (k % n);
201 if (!hash_table[position])
c67daf87 202 return (wxObject *) NULL;
c801d85f
KB
203 else
204 {
205 wxNode *node = hash_table[position]->Find (value);
206 if (node)
207 return node->Data ();
208 else
c67daf87 209 return (wxObject *) NULL;
c801d85f
KB
210 }
211}
212
debe6624 213wxObject *wxHashTable::Get (long key) const
c801d85f
KB
214{
215 // Should NEVER be
216 long k = (long) key;
217 if (k < 0)
218 k = -k;
219
220 int position = (int) (k % n);
221 if (!hash_table[position])
c67daf87 222 return (wxObject *) NULL;
c801d85f
KB
223 else
224 {
225 wxNode *node = hash_table[position]->Find (k);
226 return node ? node->Data () : (wxObject*)NULL;
227 }
228}
229
50920146 230wxObject *wxHashTable::Get (const wxChar *key) const
c801d85f
KB
231{
232 int position = (int) (MakeKey (key) % n);
233
234 if (!hash_table[position])
c67daf87 235 return (wxObject *) NULL;
c801d85f
KB
236 else
237 {
238 wxNode *node = hash_table[position]->Find (key);
239 return node ? node->Data () : (wxObject*)NULL;
240 }
241}
242
debe6624 243wxObject *wxHashTable::Delete (long key)
c801d85f
KB
244{
245 // Should NEVER be
246 long k = (long) key;
247 if (k < 0)
248 k = -k;
249
250 int position = (int) (k % n);
251 if (!hash_table[position])
c67daf87 252 return (wxObject *) NULL;
c801d85f
KB
253 else
254 {
255 wxNode *node = hash_table[position]->Find (k);
256 if (node)
257 {
258 wxObject *data = node->Data ();
259 delete node;
5692876f 260 m_count--;
c801d85f
KB
261 return data;
262 }
263 else
c67daf87 264 return (wxObject *) NULL;
c801d85f
KB
265 }
266}
267
50920146 268wxObject *wxHashTable::Delete (const wxChar *key)
c801d85f
KB
269{
270 int position = (int) (MakeKey (key) % n);
271 if (!hash_table[position])
c67daf87 272 return (wxObject *) NULL;
c801d85f
KB
273 else
274 {
275 wxNode *node = hash_table[position]->Find (key);
276 if (node)
277 {
278 wxObject *data = node->Data ();
279 delete node;
5692876f 280 m_count--;
c801d85f
KB
281 return data;
282 }
283 else
c67daf87 284 return (wxObject *) NULL;
c801d85f
KB
285 }
286}
287
debe6624 288wxObject *wxHashTable::Delete (long key, int value)
c801d85f
KB
289{
290 // Should NEVER be
291 long k = (long) key;
292 if (k < 0)
293 k = -k;
294
295 int position = (int) (k % n);
296 if (!hash_table[position])
c67daf87 297 return (wxObject *) NULL;
c801d85f
KB
298 else
299 {
300 wxNode *node = hash_table[position]->Find (value);
301 if (node)
302 {
303 wxObject *data = node->Data ();
304 delete node;
5692876f 305 m_count--;
c801d85f
KB
306 return data;
307 }
308 else
c67daf87 309 return (wxObject *) NULL;
c801d85f
KB
310 }
311}
312
50920146 313wxObject *wxHashTable::Delete (long key, const wxChar *value)
c801d85f
KB
314{
315 int position = (int) (key % n);
316 if (!hash_table[position])
c67daf87 317 return (wxObject *) NULL;
c801d85f
KB
318 else
319 {
320 wxNode *node = hash_table[position]->Find (value);
321 if (node)
322 {
323 wxObject *data = node->Data ();
324 delete node;
5692876f 325 m_count--;
c801d85f
KB
326 return data;
327 }
328 else
c67daf87 329 return (wxObject *) NULL;
c801d85f
KB
330 }
331}
332
50920146 333long wxHashTable::MakeKey (const wxChar *string) const
c801d85f
KB
334{
335 long int_key = 0;
336
337 while (*string)
50920146 338 int_key += (wxUChar) *string++;
c801d85f
KB
339
340 return int_key;
341}
342
343void wxHashTable::BeginFind (void)
344{
345 current_position = -1;
c67daf87 346 current_node = (wxNode *) NULL;
c801d85f
KB
347}
348
349wxNode *wxHashTable::Next (void)
350{
c67daf87 351 wxNode *found = (wxNode *) NULL;
c801d85f
KB
352 bool end = FALSE;
353 while (!end && !found)
354 {
355 if (!current_node)
356 {
357 current_position++;
358 if (current_position >= n)
359 {
360 current_position = -1;
c67daf87 361 current_node = (wxNode *) NULL;
c801d85f
KB
362 end = TRUE;
363 }
364 else
365 {
366 if (hash_table[current_position])
367 {
368 current_node = hash_table[current_position]->First ();
369 found = current_node;
370 }
371 }
372 }
373 else
374 {
375 current_node = current_node->Next ();
376 found = current_node;
377 }
378 }
379 return found;
380}
381
debe6624 382void wxHashTable::DeleteContents (bool flag)
c801d85f
KB
383{
384 int i;
c7fb814a 385 m_deleteContents = flag;
c801d85f
KB
386 for (i = 0; i < n; i++)
387 {
388 if (hash_table[i])
389 hash_table[i]->DeleteContents (flag);
390 }
391}
392
393void wxHashTable::Clear (void)
394{
395 int i;
396 for (i = 0; i < n; i++)
397 {
398 if (hash_table[i])
399 hash_table[i]->Clear ();
400 }
5692876f 401 m_count = 0;
c801d85f
KB
402}
403