summaryrefslogtreecommitdiffstats
path: root/sha1-lookup.c
diff options
context:
space:
mode:
authorJonathan Tan <jonathantanmy@google.com>2018-02-13 19:39:39 +0100
committerJunio C Hamano <gitster@pobox.com>2018-02-15 22:08:55 +0100
commitb4e00f7306a160639f047b3421985e8f3d0c6fb1 (patch)
treef5c1c3ffba403ad4bb1e25bac7e4f2a943a313cf /sha1-lookup.c
parentpackfile: remove GIT_DEBUG_LOOKUP log statements (diff)
downloadgit-b4e00f7306a160639f047b3421985e8f3d0c6fb1.tar.xz
git-b4e00f7306a160639f047b3421985e8f3d0c6fb1.zip
packfile: refactor hash search with fanout table
Subsequent patches will introduce file formats that make use of a fanout array and a sorted table containing hashes, just like packfiles. Refactor the hash search in packfile.c into its own function, so that those patches can make use of it as well. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'sha1-lookup.c')
-rw-r--r--sha1-lookup.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/sha1-lookup.c b/sha1-lookup.c
index 4cf3ebd921..8d0b1db3e2 100644
--- a/sha1-lookup.c
+++ b/sha1-lookup.c
@@ -99,3 +99,31 @@ int sha1_pos(const unsigned char *sha1, void *table, size_t nr,
} while (lo < hi);
return -lo-1;
}
+
+int bsearch_hash(const unsigned char *sha1, const uint32_t *fanout_nbo,
+ const unsigned char *table, size_t stride, uint32_t *result)
+{
+ uint32_t hi, lo;
+
+ hi = ntohl(fanout_nbo[*sha1]);
+ lo = ((*sha1 == 0x0) ? 0 : ntohl(fanout_nbo[*sha1 - 1]));
+
+ while (lo < hi) {
+ unsigned mi = lo + (hi - lo) / 2;
+ int cmp = hashcmp(table + mi * stride, sha1);
+
+ if (!cmp) {
+ if (result)
+ *result = mi;
+ return 1;
+ }
+ if (cmp > 0)
+ hi = mi;
+ else
+ lo = mi + 1;
+ }
+
+ if (result)
+ *result = lo;
+ return 0;
+}