mirror of
https://git.zx2c4.com/cgit
synced 2025-08-04 01:54:28 +02:00
Set prefix in snapshots when using dwimmery
This patch sets the directory prefix in archives to be the filename, excluding the suffix (.tar.gz, .tar.bz2 etc). The patch also removes the prefix parameter in cgit_print_snapshot() as the prefix might differ. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
parent
7b5cee65fd
commit
314d9ea5a3
3 changed files with 14 additions and 6 deletions
|
@ -162,10 +162,11 @@ static const char *get_ref_from_filename(const char *url, const char *filename,
|
|||
return dwim_refname;
|
||||
}
|
||||
|
||||
void cgit_print_snapshot(const char *head, const char *hex, const char *prefix,
|
||||
void cgit_print_snapshot(const char *head, const char *hex,
|
||||
const char *filename, int snapshots, int dwim)
|
||||
{
|
||||
const struct cgit_snapshot_format* f;
|
||||
char *prefix = NULL;
|
||||
|
||||
f = get_format(filename);
|
||||
if (!f) {
|
||||
|
@ -178,11 +179,20 @@ void cgit_print_snapshot(const char *head, const char *hex, const char *prefix,
|
|||
return;
|
||||
}
|
||||
|
||||
if (!hex && dwim)
|
||||
if (!hex && dwim) {
|
||||
hex = get_ref_from_filename(ctx.repo->url, filename, f);
|
||||
if (hex != NULL) {
|
||||
prefix = xstrdup(filename);
|
||||
prefix[strlen(filename) - strlen(f->suffix)] = '\0';
|
||||
}
|
||||
}
|
||||
|
||||
if (!hex)
|
||||
hex = head;
|
||||
|
||||
if (!prefix)
|
||||
prefix = xstrdup(cgit_repobasename(ctx.repo->url));
|
||||
|
||||
make_snapshot(f, hex, prefix, filename);
|
||||
free(prefix);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue