1 /**
2 Copyright: Copyright (c) 2017-2018 Andrey Penechko.
3 License: $(WEB boost.org/LICENSE_1_0.txt, Boost License 1.0).
4 Authors: Andrey Penechko.
5 */
6 module voxelman.container.hash.set;
7 
8 import std.experimental.allocator.gc_allocator;
9 import voxelman.container.hash.hashtableparts;
10 import voxelman.container.hash.keybucket;
11 
12 struct HashSet(Key, Key emptyKey, Key deletedKey, Alloc = GCAllocator)
13 {
14 	mixin HashTablePart!(KeyBucket!(Key, emptyKey, deletedKey), false);
15 }
16 
17 struct HashSet(Key, Alloc = GCAllocator)
18 {
19 	mixin HashTablePart!(MetaKeyBucket!(Key), false);
20 }
21 
22 unittest {
23 	void test(M)()
24 	{
25 		M map;
26 		map.put(2); // placed in bucket 0
27 		map.reserve(1); // capacity 2 -> 4, must be placed in bucket 2
28 		assert(map[2]);
29 	}
30 
31 	test!(HashSet!(ushort, ushort.max, ushort.max-1));
32 	test!(HashSet!(ushort));
33 }
34 
35 unittest {
36 	import std.string;
37 	void test(M)()
38 	{
39 		M map;
40 		ushort[] keys = [140,268,396,524,652,780,908,28,156,284,
41 			412,540,668,796,924,920,792,664,536,408,280,152,24];
42 
43 		foreach (i, ushort key; keys) {
44 			assert(map.length == i);
45 			map.put(key);
46 		}
47 
48 		foreach (i, ushort key; keys) {
49 			assert(map.length == keys.length - i);
50 			map.remove(key);
51 		}
52 
53 		foreach (i, ushort key; keys) {
54 			assert(map.length == i);
55 			map.put(key);
56 		}
57 	}
58 
59 	import std.stdio;
60 
61 	test!(HashSet!(ushort, ushort.max, ushort.max-1));
62 	test!(HashSet!(ushort));
63 }