Signed-off-by: Lars Hjemli <hjemli@gmail.com>
setenv("GIT_DIR", cgit_repo->path, 1);
if ((cgit_cmd == CMD_SNAPSHOT) && cgit_repo->snapshots) {
setenv("GIT_DIR", cgit_repo->path, 1);
if ((cgit_cmd == CMD_SNAPSHOT) && cgit_repo->snapshots) {
- cgit_print_snapshot(item, cgit_query_sha1,
+ cgit_print_snapshot(item, cgit_query_head, cgit_query_sha1,
cgit_repobasename(cgit_repo->url),
cgit_repobasename(cgit_repo->url),
cgit_repo->snapshots );
return;
}
cgit_repo->snapshots );
return;
}
char *rev, char *path, int ofs);
extern void cgit_commit_link(char *name, char *title, char *class, char *head,
char *rev);
char *rev, char *path, int ofs);
extern void cgit_commit_link(char *name, char *title, char *class, char *head,
char *rev);
+extern void cgit_snapshot_link(char *name, char *title, char *class,
+ char *head, char *rev, char *archivename);
extern void cgit_diff_link(char *name, char *title, char *class, char *head,
char *new_rev, char *old_rev, char *path);
extern void cgit_diff_link(char *name, char *title, char *class, char *head,
char *new_rev, char *old_rev, char *path);
extern void cgit_print_commit(char *hex);
extern void cgit_print_tag(char *revname);
extern void cgit_print_diff(const char *new_hex, const char *old_hex);
extern void cgit_print_commit(char *hex);
extern void cgit_print_tag(char *revname);
extern void cgit_print_diff(const char *new_hex, const char *old_hex);
-extern void cgit_print_snapshot(struct cacheitem *item, const char *hex,
- const char *prefix, const char *filename,
- int snapshot);
-extern void cgit_print_snapshot_links(const char *repo, const char *hex,int snapshots);
+extern void cgit_print_snapshot(struct cacheitem *item, const char *head,
+ const char *hex, const char *prefix,
+ const char *filename, int snapshot);
+extern void cgit_print_snapshot_links(const char *repo, const char *head,
+ const char *hex, int snapshots);
extern int cgit_parse_snapshots_mask(const char *str);
#endif /* CGIT_H */
extern int cgit_parse_snapshots_mask(const char *str);
#endif /* CGIT_H */
}
if (cgit_repo->snapshots) {
html("<tr><th>download</th><td colspan='2' class='sha1'>");
}
if (cgit_repo->snapshots) {
html("<tr><th>download</th><td colspan='2' class='sha1'>");
- cgit_print_snapshot_links(cgit_query_repo,hex,cgit_repo->snapshots);
+ cgit_print_snapshot_links(cgit_query_repo, cgit_query_head,
+ hex, cgit_repo->snapshots);
html("</td></tr>");
}
html("</table>\n");
html("</td></tr>");
}
html("</table>\n");
reporevlink("commit", name, title, class, head, rev, NULL);
}
reporevlink("commit", name, title, class, head, rev, NULL);
}
+void cgit_snapshot_link(char *name, char *title, char *class, char *head,
+ char *rev, char *archivename)
+{
+ reporevlink("snapshot", name, title, class, head, rev, archivename);
+}
+
void cgit_diff_link(char *name, char *title, char *class, char *head,
char *new_rev, char *old_rev, char *path)
{
void cgit_diff_link(char *name, char *title, char *class, char *head,
char *new_rev, char *old_rev, char *path)
{
{ ".tar", "application/x-tar", write_tar_archive, 0x8 }
};
{ ".tar", "application/x-tar", write_tar_archive, 0x8 }
};
-void cgit_print_snapshot(struct cacheitem *item, const char *hex,
- const char *prefix, const char *filename,
- int snapshots)
+void cgit_print_snapshot(struct cacheitem *item, const char *head,
+ const char *hex, const char *prefix,
+ const char *filename, int snapshots)
{
int fnl = strlen(filename);
{
int fnl = strlen(filename);
- int f;
- for(f=0;f<(sizeof(snapshot_archives)/sizeof(*snapshot_archives));++f) {
+ int f, n;
+
+ n = sizeof(snapshot_archives) / sizeof(*snapshot_archives);
+ for(f=0; f<n; f++) {
const struct snapshot_archive_t* sat = &snapshot_archives[f];
int sl;
const struct snapshot_archive_t* sat = &snapshot_archives[f];
int sl;
- if(!(snapshots&sat->bit)) continue;
+ if(!(snapshots & sat->bit))
+ continue;
sl = strlen(sat->suffix);
if(fnl<sl || strcmp(&filename[fnl-sl],sat->suffix))
continue;
sl = strlen(sat->suffix);
if(fnl<sl || strcmp(&filename[fnl-sl],sat->suffix))
continue;
struct commit *commit;
unsigned char sha1[20];
struct commit *commit;
unsigned char sha1[20];
+ if (!hex)
+ hex = head;
if(get_sha1(hex, sha1)) {
cgit_print_error(fmt("Bad object id: %s", hex));
return;
if(get_sha1(hex, sha1)) {
cgit_print_error(fmt("Bad object id: %s", hex));
return;
cgit_print_error(fmt("Unsupported snapshot format: %s", filename));
}
cgit_print_error(fmt("Unsupported snapshot format: %s", filename));
}
-void cgit_print_snapshot_links(const char *repo,const char *hex,int snapshots)
+void cgit_print_snapshot_links(const char *repo, const char *head,
+ const char *hex, int snapshots)
- int f;
- for(f=0;f<(sizeof(snapshot_archives)/sizeof(*snapshot_archives));++f) {
+ int f, n;
+
+ n = sizeof(snapshot_archives) / sizeof(*snapshot_archives);
+ for(f=0; f<n ;f++) {
const struct snapshot_archive_t* sat = &snapshot_archives[f];
const struct snapshot_archive_t* sat = &snapshot_archives[f];
- if(!(snapshots&sat->bit)) continue;
- filename = fmt("%s-%s%s",cgit_repobasename(repo),hex,sat->suffix);
- htmlf("<a href='%s'>%s</a><br/>",
- cgit_fileurl(repo,"snapshot",filename,
- fmt("id=%s&name=%s",hex,filename)), filename);
+ if(!(snapshots & sat->bit))
+ continue;
+ filename = fmt("%s-%s%s", cgit_repobasename(repo), hex,
+ sat->suffix);
+ cgit_snapshot_link(filename, NULL, NULL, (char *)head,
+ (char *)hex, filename);
+ html("<br/>");