diff options
author | Junio C Hamano <junkio@cox.net> | 2006-02-12 03:51:19 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-02-12 14:12:39 +0100 |
commit | 2b796360acbdf3186ab9a5dcb84fe416eda4ffd5 (patch) | |
tree | 69299088522856a61ccab7d07eabf3f6c6ce4bd6 /object.c | |
parent | Use a hashtable for objects instead of a sorted list (diff) | |
download | git-2b796360acbdf3186ab9a5dcb84fe416eda4ffd5.tar.xz git-2b796360acbdf3186ab9a5dcb84fe416eda4ffd5.zip |
hashtable-based objects: minimum fixups.
Calling hashtable_index from find_object before objs is created
would result in division by zero failure. Avoid it.
Also the given object name may not be aligned suitably for
unsigned int; avoid dereferencing casted pointer.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'object.c')
-rw-r--r-- | object.c | 6 |
1 files changed, 4 insertions, 2 deletions
@@ -13,17 +13,19 @@ int track_object_refs = 1; static int hashtable_index(const unsigned char *sha1) { - unsigned int i = *(unsigned int *)sha1; + unsigned int i; + memcpy(&i, sha1, sizeof(unsigned int)); return (int)(i % obj_allocs); } static int find_object(const unsigned char *sha1) { - int i = hashtable_index(sha1); + int i; if (!objs) return -1; + i = hashtable_index(sha1); while (objs[i]) { if (memcmp(sha1, objs[i]->sha1, 20) == 0) return i; |