summaryrefslogtreecommitdiff
path: root/src/listhash.h
blob: e5ec4ee2b40addbfce91ac573212ad1671db8fd8 (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
/*
 * Copyright (C) 2007-2010 Xagasoft, All rights reserved.
 *
 * This file is part of the libbu++ library and is released under the
 * terms of the license contained in the file LICENSE.
 */

#ifndef BU_LIST_HASH_H
#define BU_LIST_HASH_H

#include "bu/hash.h"
#include "bu/list.h"

namespace Bu
{
	template<typename key, typename value, typename sizecalc = __calcNextTSize_fast, typename keyalloc = std::allocator<key>, typename valuealloc = std::allocator<Bu::List<value> >, typename challoc = std::allocator<uint32_t> >
	class ListHash : public Hash<key, Bu::List<value>, sizecalc, keyalloc, valuealloc, challoc>
	{
		typedef Hash<key, Bu::List<value>, sizecalc, keyalloc, valuealloc, challoc> ParentType;
	public:
		ListHash()
		{
		}

		ListHash( const ListHash &src ) :
			ParentType( src )
		{
		}

		virtual ~ListHash()
		{
		}

		ListHash &operator=( const ListHash &src )
		{
			*dynamic_cast<ParentType *>(this) =
				dynamic_cast<ParentType &>(src);
		}

		virtual void insert( const key &k, const value &v )
		{
			if( !has( k ) )
			{
				ParentType::insert( k, List<value>() );
			}
			get( k ).append( v );
		}
		
	private:
	};

};

#endif