about summary refs log tree commit diff stats
path: root/ui-snapshot.c
diff options
context:
space:
mode:
authorJohn Keeping2018-03-31 15:18:57 +0100
committerJason A. Donenfeld2018-06-27 18:11:19 +0200
commitd85e8a9810cbfbe5cfe80509a7b47cb39483e6ac (patch)
tree90e9efd9388639875d695fa12323270f10490bef /ui-snapshot.c
parentui-shared: pass repo object to print_snapshot_links() (diff)
downloadcgit-d85e8a9810cbfbe5cfe80509a7b47cb39483e6ac.tar.gz
cgit-d85e8a9810cbfbe5cfe80509a7b47cb39483e6ac.zip
ui-snapshot: pass repo into get_ref_from_filename()
Prepare to allow a custom snapshot prefix.

Signed-off-by: John Keeping <john@keeping.me.uk>
Reviewed-by: Christian Hesse <mail@eworm.de>
Diffstat (limited to 'ui-snapshot.c')
-rw-r--r--ui-snapshot.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/ui-snapshot.c b/ui-snapshot.c index b2d95f7..237a75f 100644 --- a/ui-snapshot.c +++ b/ui-snapshot.c
@@ -139,7 +139,8 @@ static int make_snapshot(const struct cgit_snapshot_format *format,
139 * pending a 'v' or a 'V' to the remaining snapshot name ("0.7.2" -> 139 * pending a 'v' or a 'V' to the remaining snapshot name ("0.7.2" ->
140 * "v0.7.2") gives us something valid. 140 * "v0.7.2") gives us something valid.
141 */ 141 */
142static const char *get_ref_from_filename(const char *url, const char *filename, 142static const char *get_ref_from_filename(const struct cgit_repo *repo,
143 const char *filename,
143 const struct cgit_snapshot_format *format) 144 const struct cgit_snapshot_format *format)
144{ 145{
145 const char *reponame; 146 const char *reponame;
@@ -153,7 +154,7 @@ static const char *get_ref_from_filename(const char *url, const char *filename,
153 if (get_oid(snapshot.buf, &oid) == 0) 154 if (get_oid(snapshot.buf, &oid) == 0)
154 goto out; 155 goto out;
155 156
156 reponame = cgit_repobasename(url); 157 reponame = cgit_repobasename(repo->url);
157 if (starts_with(snapshot.buf, reponame)) { 158 if (starts_with(snapshot.buf, reponame)) {
158 const char *new_start = snapshot.buf; 159 const char *new_start = snapshot.buf;
159 new_start += strlen(reponame); 160 new_start += strlen(reponame);
@@ -200,7 +201,7 @@ void cgit_print_snapshot(const char *head, const char *hex,
200 } 201 }
201 202
202 if (!hex && dwim) { 203 if (!hex && dwim) {
203 hex = get_ref_from_filename(ctx.repo->url, filename, f); 204 hex = get_ref_from_filename(ctx.repo, filename, f);
204 if (hex == NULL) { 205 if (hex == NULL) {
205 cgit_print_error_page(404, "Not found", "Not found"); 206 cgit_print_error_page(404, "Not found", "Not found");
206 return; 207 return;