Factorizing code fixes off-by-one error in the duplicated code (caused mostly harmless anticipated growing of the array). Signed-off-by: Yann Dirson <ydirson@xxxxxxxxxx> --- commit.c | 62 +++++++++++++++++++++++++++----------------------------------- 1 files changed, 27 insertions(+), 35 deletions(-) diff --git a/commit.c b/commit.c index 2d9265d..b7aeee4 100644 --- a/commit.c +++ b/commit.c @@ -6,6 +6,7 @@ #include "diff.h" #include "revision.h" #include "notes.h" +#include "sorted-array.h" int save_commit_buffer = 1; @@ -76,33 +77,37 @@ static unsigned long parse_commit_date(const char *buf, const char *tail) return strtoul(dateptr, NULL, 10); } -static struct commit_graft **commit_graft; -static int commit_graft_alloc, commit_graft_nr; - -static int commit_graft_pos(const unsigned char *sha1) +static int commit_graft_cmp(const unsigned char *ref_sha1, struct commit_graft **elem) { - int lo, hi; - lo = 0; - hi = commit_graft_nr; - while (lo < hi) { - int mi = (lo + hi) / 2; - struct commit_graft *graft = commit_graft[mi]; - int cmp = hashcmp(sha1, graft->sha1); - if (!cmp) - return mi; - if (cmp < 0) - hi = mi; - else - lo = mi + 1; - } - return -lo - 1; + return hashcmp(ref_sha1, (*elem)->sha1); } +declare_sorted_array(static, struct commit_graft *, commit_graft); +declare_gen_binsearch(static, struct commit_graft *, _commit_graft_pos, + const unsigned char *); +declare_sorted_array_search_check(static, commit_graft_pos, const unsigned char *, + _commit_graft_pos, commit_graft, commit_graft_cmp); +// FIXME: do we want to/can we remove INITTYPE from gen_binsearch ? +static int commit_graft_cmp2(struct commit_graft *ref_graft, struct commit_graft **elem) +{ + return commit_graft_cmp(ref_graft->sha1, elem); +} +declare_gen_binsearch(static, struct commit_graft *, _commit_graft_pos2, + struct commit_graft *); +static void commit_graft_init(struct commit_graft **elem, struct commit_graft *ref_graft) +{ + *elem = ref_graft; +} +declare_gen_sorted_insert(static, struct commit_graft *, _register_commit_graft0, + _commit_graft_pos2, struct commit_graft *) +declare_sorted_array_insert_check(static, register_commit_graft0, struct commit_graft *, + _register_commit_graft0, commit_graft, + commit_graft_cmp2, commit_graft_init); int register_commit_graft(struct commit_graft *graft, int ignore_dups) { - int pos = commit_graft_pos(graft->sha1); + int pos = register_commit_graft0(graft); - if (0 <= pos) { + if (pos >= 0) { if (ignore_dups) free(graft); else { @@ -111,19 +116,6 @@ int register_commit_graft(struct commit_graft *graft, int ignore_dups) } return 1; } - pos = -pos - 1; - if (commit_graft_alloc <= ++commit_graft_nr) { - commit_graft_alloc = alloc_nr(commit_graft_alloc); - commit_graft = xrealloc(commit_graft, - sizeof(*commit_graft) * - commit_graft_alloc); - } - if (pos < commit_graft_nr) - memmove(commit_graft + pos + 1, - commit_graft + pos, - (commit_graft_nr - pos - 1) * - sizeof(*commit_graft)); - commit_graft[pos] = graft; return 0; } -- 1.7.2.3 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html