cgit.c: use resolve_ref() to guess_defbranch()
The resolve_ref() function handles reading of git- and filesystem symbolic links (including proper whitespace trimming) and packed refs. There's no point in reimplementing this function in cgit. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
szülő
e95c70d4ea
commit
8d7c2ec295
32
cgit.c
32
cgit.c
@ -418,33 +418,13 @@ char *find_default_branch(struct cgit_repo *repo)
|
|||||||
|
|
||||||
static char *guess_defbranch(const char *repo_path)
|
static char *guess_defbranch(const char *repo_path)
|
||||||
{
|
{
|
||||||
int fd, len;
|
const char *ref;
|
||||||
char buffer[256];
|
unsigned char sha1[20];
|
||||||
char *ref_start;
|
|
||||||
char *head;
|
|
||||||
|
|
||||||
head = fmt("%s/HEAD", repo_path);
|
ref = resolve_ref("HEAD", sha1, 0, NULL);
|
||||||
fd = open(head, O_RDONLY);
|
if (!ref || prefixcmp(ref, "refs/heads/"))
|
||||||
if (fd == -1)
|
return "master";
|
||||||
return xstrdup("master");
|
return xstrdup(ref + 11);
|
||||||
|
|
||||||
memset(buffer, 0, sizeof(buffer));
|
|
||||||
len = read_in_full(fd, buffer, sizeof(buffer) - 1);
|
|
||||||
close(fd);
|
|
||||||
|
|
||||||
if(!memcmp(buffer, "ref: refs/heads/", 16))
|
|
||||||
return xstrndup(buffer + 16, len - 17);
|
|
||||||
|
|
||||||
if(strlen(buffer) == 41) {
|
|
||||||
/* probably contains a SHA1 sum */
|
|
||||||
memset(buffer, 0, sizeof(buffer));
|
|
||||||
if(readlink(head, buffer, sizeof(buffer)-1)) {
|
|
||||||
ref_start = memmem(buffer, sizeof(buffer)-1, "refs/heads/", 11);
|
|
||||||
if(ref_start)
|
|
||||||
return xstrdup(ref_start+11);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return xstrdup("master");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int prepare_repo_cmd(struct cgit_context *ctx)
|
static int prepare_repo_cmd(struct cgit_context *ctx)
|
||||||
|
Betöltés…
x
Reference in New Issue
Block a user