if (readfile(path, &buf, &size))
return -1;
- if (parse_date(buf, buf2, sizeof(buf2)))
+ if (parse_date(buf, buf2, sizeof(buf2)) > 0)
result = strtoul(buf2, NULL, 10);
else
result = 0;
return 1;
}
- path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch);
- if (stat(path, &s) == 0)
+ path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch ?
+ repo->defbranch : "master");
+ if (stat(path, &s) == 0) {
*mtime = s.st_mtime;
- else
- *mtime = 0;
+ r->mtime = *mtime;
+ return 1;
+ }
+
+ path = fmt("%s/%s", repo->path, "packed-refs");
+ if (stat(path, &s) == 0) {
+ *mtime = s.st_mtime;
+ r->mtime = *mtime;
+ return 1;
+ }
+ *mtime = 0;
r->mtime = *mtime;
return (r->mtime != 0);
}
}
-void print_pager(int items, int pagelen, char *search)
+void print_pager(int items, int pagelen, char *search, char *sort)
{
int i;
html("<div class='pager'>");
for(i = 0; i * pagelen < items; i++)
cgit_index_link(fmt("[%d]", i+1), fmt("Page %d", i+1), NULL,
- search, i * pagelen);
+ search, sort, i * pagelen);
html("</div>");
}
if (!hits)
cgit_print_error("No repositories found");
else if (hits > ctx.cfg.max_repo_count)
- print_pager(hits, ctx.cfg.max_repo_count, ctx.qry.search);
+ print_pager(hits, ctx.cfg.max_repo_count, ctx.qry.search, ctx.qry.sort);
cgit_print_docend();
}
if (!ctx.cfg.root_readme)
return;
if (ctx.cfg.about_filter)
- cgit_open_filter(ctx.cfg.about_filter, NULL);
+ cgit_open_filter(ctx.cfg.about_filter);
html_include(ctx.cfg.root_readme);
if (ctx.cfg.about_filter)
cgit_close_filter(ctx.cfg.about_filter);