all repos — cgit @ aee990b6a4512e52b1279a0633d112afe2440122

a hyperfast web frontend for git written in c

cgit: replace 'unsigned char sha1[20]' with 'struct object_id oid'

Upstream git is replacing 'unsigned char sha1[20]' with 'struct object_id
oid'. We have some code that can be changed independent from upstream. So
here we go...
Christian Hesse mail@eworm.de
Thu, 29 Sep 2016 21:16:14 +0200
commit

aee990b6a4512e52b1279a0633d112afe2440122

parent

ef3108656b9c6e22604c18bd9d05bdc847d81e87

1 files changed, 5 insertions(+), 4 deletions(-)

jump to
M cgit.ccgit.c

@@ -471,13 +471,14 @@

static char *guess_defbranch(void) { const char *ref; - unsigned char sha1[20]; + struct object_id oid; - ref = resolve_ref_unsafe("HEAD", 0, sha1, NULL); + ref = resolve_ref_unsafe("HEAD", 0, oid.hash, NULL); if (!ref || !starts_with(ref, "refs/heads/")) return "master"; return xstrdup(ref + 11); } + /* The caller must free filename and ref after calling this. */ static inline void parse_readme(const char *readme, char **filename, char **ref, struct cgit_repo *repo) {

@@ -557,7 +558,7 @@ }

static int prepare_repo_cmd(void) { - unsigned char sha1[20]; + struct object_id oid; int nongit = 0; int rc;

@@ -615,7 +616,7 @@ cgit_print_docend();

return 1; } - if (get_sha1(ctx.qry.head, sha1)) { + if (get_oid(ctx.qry.head, &oid)) { char *old_head = ctx.qry.head; ctx.qry.head = xstrdup(ctx.repo->defbranch); cgit_print_error_page(404, "Not found",