X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/a4d1ca1dc6ff8171694d9e2280b6075a1beced0c..c6431a71508f1b61a95b01d85fe4534a0245e626:/ui-repolist.c diff --git a/ui-repolist.c b/ui-repolist.c index eeeaf3d..3f78e28 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -44,9 +44,36 @@ static void print_modtime(struct cgit_repo *repo) cgit_print_age(s.st_mtime, -1, NULL); } +int is_match(struct cgit_repo *repo) +{ + if (!ctx.qry.search) + return 1; + if (repo->url && strcasestr(repo->url, ctx.qry.search)) + return 1; + if (repo->name && strcasestr(repo->name, ctx.qry.search)) + return 1; + if (repo->desc && strcasestr(repo->desc, ctx.qry.search)) + return 1; + if (repo->owner && strcasestr(repo->owner, ctx.qry.search)) + return 1; + return 0; +} + +void print_header(int columns) +{ + html("" + "Name" + "Description" + "Owner" + "Idle"); + if (ctx.cfg.enable_index_links) + html("Links"); + html("\n"); +} + void cgit_print_repolist() { - int i, columns = 4; + int i, columns = 4, hits = 0, header = 0; char *last_group = NULL; if (ctx.cfg.enable_index_links) @@ -57,24 +84,17 @@ void cgit_print_repolist() cgit_print_docstart(&ctx); cgit_print_pageheader(&ctx); - html(""); - if (ctx.cfg.index_header) { - htmlf(""); - } - html("" - "" - "" - "" - ""); - if (ctx.cfg.enable_index_links) - html(""); - html("\n"); + html("
", - columns); + if (ctx.cfg.index_header) html_include(ctx.cfg.index_header); - html("
NameDescriptionOwnerIdleLinks
"); for (i=0; igroup != NULL) || (last_group != NULL && ctx.repo->group == NULL) || (last_group != NULL && ctx.repo->group != NULL && @@ -91,7 +111,9 @@ void cgit_print_repolist() html_txt(ctx.repo->name); html_link_close(); html("\n"); } html("
"); + html_link_open(cgit_repourl(ctx.repo->url), NULL, NULL); html_ntxt(ctx.cfg.max_repodesc_len, ctx.repo->desc); + html_link_close(); html(""); html_txt(ctx.repo->owner); html(""); @@ -110,5 +132,13 @@ void cgit_print_repolist() html("
"); + if (!hits) + cgit_print_error("No repositories found"); cgit_print_docend(); } + +void cgit_print_site_readme() +{ + if (ctx.cfg.root_readme) + html_include(ctx.cfg.root_readme); +}