Do not alter incoming sha1 when handling the download refs.
The code used to overwrite the const sha1 parameter just to avoid declaring an extra variable. Fix it. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
vanhempi
ea2831f1c8
commit
cfd2aa0797
@ -130,6 +130,7 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1,
|
|||||||
struct taginfo *info;
|
struct taginfo *info;
|
||||||
struct object *obj;
|
struct object *obj;
|
||||||
char buf[256], *url;
|
char buf[256], *url;
|
||||||
|
unsigned char fileid[20];
|
||||||
|
|
||||||
if (prefixcmp(refname, "refs/archives"))
|
if (prefixcmp(refname, "refs/archives"))
|
||||||
return 0;
|
return 0;
|
||||||
@ -141,9 +142,11 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1,
|
|||||||
tag = lookup_tag(sha1);
|
tag = lookup_tag(sha1);
|
||||||
if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
|
if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
|
||||||
return 0;
|
return 0;
|
||||||
hashcpy(sha1, tag->tagged->sha1);
|
hashcpy(fileid, tag->tagged->sha1);
|
||||||
} else if (obj->type != OBJ_BLOB) {
|
} else if (obj->type != OBJ_BLOB) {
|
||||||
return 0;
|
return 0;
|
||||||
|
} else {
|
||||||
|
hashcpy(fileid, sha1);
|
||||||
}
|
}
|
||||||
if (!header) {
|
if (!header) {
|
||||||
html("<table>");
|
html("<table>");
|
||||||
@ -152,7 +155,7 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1,
|
|||||||
}
|
}
|
||||||
html("<tr><td>");
|
html("<tr><td>");
|
||||||
url = cgit_pageurl(cgit_query_repo, "blob",
|
url = cgit_pageurl(cgit_query_repo, "blob",
|
||||||
fmt("id=%s&path=%s", sha1_to_hex(sha1),
|
fmt("id=%s&path=%s", sha1_to_hex(fileid),
|
||||||
buf));
|
buf));
|
||||||
html_link_open(url, NULL, NULL);
|
html_link_open(url, NULL, NULL);
|
||||||
html_txt(buf);
|
html_txt(buf);
|
||||||
|
Ladataan…
Viittaa uudesa ongelmassa
Block a user