Pārlūkot izejas kodu

Implement hashing for symbol table.

master
Ben Kurtovic pirms 9 gadiem
vecāks
revīzija
2c4e26de02
1 mainītis faili ar 7 papildinājumiem un 2 dzēšanām
  1. +7
    -2
      src/assembler/state.c

+ 7
- 2
src/assembler/state.c Parādīt failu

@@ -129,11 +129,16 @@ void asm_symtable_free(ASMSymbolTable *symtable)
}

/*
...
Hash a string key into a symbol table bucket index.

This uses the djb2 algorithm: http://www.cse.yorku.ca/~oz/hash.html
*/
static inline size_t hash_key(const char *key)
{
return 0;
size_t hash = 5381;
while (*key)
hash = ((hash << 5) + hash) + *(key++);
return hash % SYMBOL_TABLE_BUCKETS;
}

/*


Notiek ielāde…
Atcelt
Saglabāt