This is a bugfix as well as an improvement to the HTTP status code
handling since previously we would not print HTTP headers on any of
these code paths.
Signed-off-by: John Keeping <john@keeping.me.uk>
if (hex) {
if (get_sha1_hex(hex, sha1)) {
if (hex) {
if (get_sha1_hex(hex, sha1)) {
- cgit_print_error("Bad hex value: %s", hex);
+ cgit_print_error_page(400, "Bad request",
+ "Bad hex value: %s", hex);
return;
}
} else {
if (get_sha1(head, sha1)) {
return;
}
} else {
if (get_sha1(head, sha1)) {
- cgit_print_error("Bad ref: %s", head);
+ cgit_print_error_page(404, "Not found",
+ "Bad ref: %s", head);
- cgit_print_error("Bad object name: %s", hex);
+ cgit_print_error_page(404, "Not found",
+ "Bad object name: %s", hex);
return;
}
buf = read_sha1_file(sha1, &type, &size);
if (!buf) {
return;
}
buf = read_sha1_file(sha1, &type, &size);
if (!buf) {
- cgit_print_error("Error reading object %s", hex);
+ cgit_print_error_page(500, "Internal server error",
+ "Error reading object %s", hex);