summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-snapshot.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/ui-snapshot.c b/ui-snapshot.c
index 6f09151..f98f5d7 100644
--- a/ui-snapshot.c
+++ b/ui-snapshot.c
@@ -162,31 +162,33 @@ void cgit_print_snapshot(const char *head, const char *hex,
162 const struct cgit_snapshot_format* f; 162 const struct cgit_snapshot_format* f;
163 char *prefix = NULL; 163 char *prefix = NULL;
164 164
165 f = get_format(filename); 165 f = get_format(filename);
166 if (!f) { 166 if (!f) {
167 ctx.page.mimetype = "text/html"; 167 ctx.page.mimetype = "text/html";
168 cgit_print_http_headers(&ctx); 168 cgit_print_http_headers(&ctx);
169 cgit_print_docstart(&ctx); 169 cgit_print_docstart(&ctx);
170 cgit_print_pageheader(&ctx); 170 cgit_print_pageheader(&ctx);
171 cgit_print_error(fmt("Unsupported snapshot format: %s", filename)); 171 cgit_print_error(fmt("Unsupported snapshot format: %s", filename));
172 cgit_print_docend(); 172 cgit_print_docend();
173 return; 173 return;
174 } 174 }
175 175
176 if (!hex && dwim) { 176 if (!hex && dwim) {
177 hex = get_ref_from_filename(ctx.repo->url, filename, f); 177 hex = get_ref_from_filename(ctx.repo->url, filename, f);
178 if (hex != NULL) { 178 if (hex == NULL) {
179 prefix = xstrdup(filename); 179 html_status(404, "Not found", 0);
180 prefix[strlen(filename) - strlen(f->suffix)] = '\0'; 180 return;
181 } 181 }
182 prefix = xstrdup(filename);
183 prefix[strlen(filename) - strlen(f->suffix)] = '\0';
182 } 184 }
183 185
184 if (!hex) 186 if (!hex)
185 hex = head; 187 hex = head;
186 188
187 if (!prefix) 189 if (!prefix)
188 prefix = xstrdup(cgit_repobasename(ctx.repo->url)); 190 prefix = xstrdup(cgit_repobasename(ctx.repo->url));
189 191
190 make_snapshot(f, hex, prefix, filename); 192 make_snapshot(f, hex, prefix, filename);
191 free(prefix); 193 free(prefix);
192} 194}