2 * Copyright (c) 2009 Joshua Phillips. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
15 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
16 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18 * DISCLAIMED. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY
19 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
21 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
23 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
25 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 struct sym
*hash_prev
;
44 static struct sym
*hashtab
[MAX_HASH
];
46 static int hash(const char *str
)
48 unsigned int hash
= 0;
50 hash
= hash
* 263 + *str
;
53 return hash
% MAX_HASH
;
56 void symtab_init(void)
58 memset(hashtab
, 0, sizeof hashtab
);
61 int symtab_insert(const char *name
, uintptr_t value
)
63 const int h
= hash(name
);
69 if (!strcmp(name
, s
->name
)){
70 // already in the symbol table
76 // insert into hash table
77 s
= malloc(sizeof *s
+ strlen(name
));
83 strcpy(s
->name
, name
);
85 s
->hash_prev
= hashtab
[h
];
90 uintptr_t symtab_lookup(const char *name
)
97 if (!strcmp(name
, s
->name
)){