author | Lars Hjemli <hjemli@gmail.com> | 2008-08-06 20:57:44 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-08-06 20:57:44 (UTC) |
commit | 885096c189574b1cf2e0897cc05aadd7b092a677 (patch) (unidiff) | |
tree | e915e78aa09d61a3492926f2eb8a1a3e59c60f4d /ui-clone.c | |
parent | 65b7b876aaaf50fc15060533359d6561f4f1819a (diff) | |
download | cgit-885096c189574b1cf2e0897cc05aadd7b092a677.zip cgit-885096c189574b1cf2e0897cc05aadd7b092a677.tar.gz cgit-885096c189574b1cf2e0897cc05aadd7b092a677.tar.bz2 |
Supply status description to html_status()
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | ui-clone.c | 10 |
1 files changed, 4 insertions, 6 deletions
@@ -43,30 +43,28 @@ static void print_pack_info(struct cgit_context *ctx) | |||
43 | for (pack = packed_git; pack; pack = pack->next) | 43 | for (pack = packed_git; pack; pack = pack->next) |
44 | if (pack->pack_local) | 44 | if (pack->pack_local) |
45 | htmlf("P %s\n", pack->pack_name + ofs); | 45 | htmlf("P %s\n", pack->pack_name + ofs); |
46 | } | 46 | } |
47 | 47 | ||
48 | static void send_file(struct cgit_context *ctx, char *path) | 48 | static void send_file(struct cgit_context *ctx, char *path) |
49 | { | 49 | { |
50 | struct stat st; | 50 | struct stat st; |
51 | int err; | ||
52 | 51 | ||
53 | if (stat(path, &st)) { | 52 | if (stat(path, &st)) { |
54 | switch (errno) { | 53 | switch (errno) { |
55 | case ENOENT: | 54 | case ENOENT: |
56 | err = 404; | 55 | html_status(404, "Not found", 0); |
57 | break; | 56 | break; |
58 | case EACCES: | 57 | case EACCES: |
59 | err = 403; | 58 | html_status(403, "Forbidden", 0); |
60 | break; | 59 | break; |
61 | default: | 60 | default: |
62 | err = 400; | 61 | html_status(400, "Bad request", 0); |
63 | } | 62 | } |
64 | html_status(err, 0); | ||
65 | return; | 63 | return; |
66 | } | 64 | } |
67 | ctx->page.mimetype = "application/octet-stream"; | 65 | ctx->page.mimetype = "application/octet-stream"; |
68 | ctx->page.filename = path; | 66 | ctx->page.filename = path; |
69 | if (prefixcmp(ctx->repo->path, path)) | 67 | if (prefixcmp(ctx->repo->path, path)) |
70 | ctx->page.filename += strlen(ctx->repo->path) + 1; | 68 | ctx->page.filename += strlen(ctx->repo->path) + 1; |
71 | cgit_print_http_headers(ctx); | 69 | cgit_print_http_headers(ctx); |
72 | html_include(path); | 70 | html_include(path); |
@@ -81,17 +79,17 @@ void cgit_clone_info(struct cgit_context *ctx) | |||
81 | ctx->page.filename = "info/refs"; | 79 | ctx->page.filename = "info/refs"; |
82 | cgit_print_http_headers(ctx); | 80 | cgit_print_http_headers(ctx); |
83 | for_each_ref(print_ref_info, ctx); | 81 | for_each_ref(print_ref_info, ctx); |
84 | } | 82 | } |
85 | 83 | ||
86 | void cgit_clone_objects(struct cgit_context *ctx) | 84 | void cgit_clone_objects(struct cgit_context *ctx) |
87 | { | 85 | { |
88 | if (!ctx->qry.path) { | 86 | if (!ctx->qry.path) { |
89 | html_status(400, 0); | 87 | html_status(400, "Bad request", 0); |
90 | return; | 88 | return; |
91 | } | 89 | } |
92 | 90 | ||
93 | if (!strcmp(ctx->qry.path, "info/packs")) { | 91 | if (!strcmp(ctx->qry.path, "info/packs")) { |
94 | print_pack_info(ctx); | 92 | print_pack_info(ctx); |
95 | return; | 93 | return; |
96 | } | 94 | } |
97 | 95 | ||