annotate dmd/StringTable.d @ 0:10317f0c89a5

Initial commit
author korDen
date Sat, 24 Oct 2009 08:42:06 +0400
parents
children 7427ded8caf7
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.StringTable;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
3 import dmd.StringValue;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.StringEntry;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.Dchar;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import core.stdc.stdlib;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import core.stdc.string;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 class StringTable
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 void** table;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 uint count;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 uint tabledim;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 this(uint size = 37)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 table = cast(void**)calloc(size, (void*).sizeof);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 memset(table, 0, size * (void*).sizeof);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 tabledim = size;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 count = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 ~this()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 /// TODO: is it *really* needed?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 // Zero out dangling pointers to help garbage collector.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 // Should zero out StringEntry's too.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 ///for (uint i = 0; i < count; i++) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 /// table[i] = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 ///}
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 free(table);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 //table = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 StringValue* lookup(immutable(dchar_t)[] s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39 StringEntry* se = *cast(StringEntry**)search(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 if (se !is null)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 return &se.value;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 return null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46 StringValue* insert(immutable(dchar_t)[] s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 StringEntry** pse = cast(StringEntry**)search(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 StringEntry* se = *pse;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 if (se !is null)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51 return null; // error: already in table
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 se = new StringEntry(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 *pse = se;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
56 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 return &se.value;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61 StringValue* update(immutable(dchar_t)[] s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 StringEntry **pse;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 StringEntry *se;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66 pse = cast(StringEntry**)search(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67 se = *pse;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
68 if (se is null) // not in table: so create new entry
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
69 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70 se = new StringEntry(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71 *pse = se;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73 return &se.value;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 private:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 void** search(immutable(dchar_t)[] s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 int cmp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 //printf("StringTable::search(%p,%d)\n",s,len);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 hash_t hash = Dchar.calcHash(s.ptr, s.length);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 uint u = hash % tabledim;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 StringEntry** se = cast(StringEntry**)&table[u];
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85 //printf("\thash = %d, u = %d\n",hash,u);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86 while (*se)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 cmp = (*se).hash - hash;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89 if (cmp == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 cmp = (*se).value.lstring.len() - s.length;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92 if (cmp == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 cmp = Dchar.memcmp(s.ptr, (*se).value.lstring.toDchars().ptr, s.length);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 if (cmp == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
98 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
99 if (cmp < 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
100 se = &(*se).left;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
101 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
102 se = &(*se).right;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
105 //printf("\treturn %p, %p\n",se, (*se));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106 return cast(void**)se;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108 }