1 | /********** |
2 | This library is free software; you can redistribute it and/or modify it under |
3 | the terms of the GNU Lesser General Public License as published by the |
4 | Free Software Foundation; either version 3 of the License, or (at your |
5 | option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.) |
6 | |
7 | This library is distributed in the hope that it will be useful, but WITHOUT |
8 | ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
9 | FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for |
10 | more details. |
11 | |
12 | You should have received a copy of the GNU Lesser General Public License |
13 | along with this library; if not, write to the Free Software Foundation, Inc., |
14 | 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
15 | **********/ |
16 | // Copyright (c) 1996-2020 Live Networks, Inc. All rights reserved. |
17 | // Generic Hash Table |
18 | // Implementation |
19 | |
20 | #include "HashTable.hh" |
21 | |
22 | HashTable::HashTable() { |
23 | } |
24 | |
25 | HashTable::~HashTable() { |
26 | } |
27 | |
28 | HashTable::Iterator::Iterator() { |
29 | } |
30 | |
31 | HashTable::Iterator::~Iterator() {} |
32 | |
33 | void* HashTable::RemoveNext() { |
34 | Iterator* iter = Iterator::create(*this); |
35 | char const* key; |
36 | void* removedValue = iter->next(key); |
37 | if (removedValue != 0) Remove(key); |
38 | |
39 | delete iter; |
40 | return removedValue; |
41 | } |
42 | |
43 | void* HashTable::getFirst() { |
44 | Iterator* iter = Iterator::create(*this); |
45 | char const* key; |
46 | void* firstValue = iter->next(key); |
47 | |
48 | delete iter; |
49 | return firstValue; |
50 | } |
51 | |