ui-repolist: enable filtering of repos by path
If a repo url is specified but no exact match is found in the list of repos the url will now be used as a prefix-filter. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
parent
93397a765b
commit
dd80ef59e7
@ -59,6 +59,15 @@ int is_match(struct cgit_repo *repo)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int is_in_url(struct cgit_repo *repo)
|
||||||
|
{
|
||||||
|
if (!ctx.qry.url)
|
||||||
|
return 1;
|
||||||
|
if (repo->url && !prefixcmp(repo->url, ctx.qry.url))
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void print_header(int columns)
|
void print_header(int columns)
|
||||||
{
|
{
|
||||||
html("<tr class='nohover'>"
|
html("<tr class='nohover'>"
|
||||||
@ -101,7 +110,7 @@ void cgit_print_repolist()
|
|||||||
html("<table summary='repository list' class='list nowrap'>");
|
html("<table summary='repository list' class='list nowrap'>");
|
||||||
for (i=0; i<cgit_repolist.count; i++) {
|
for (i=0; i<cgit_repolist.count; i++) {
|
||||||
ctx.repo = &cgit_repolist.repos[i];
|
ctx.repo = &cgit_repolist.repos[i];
|
||||||
if (!is_match(ctx.repo))
|
if (!(is_match(ctx.repo) && is_in_url(ctx.repo)))
|
||||||
continue;
|
continue;
|
||||||
hits++;
|
hits++;
|
||||||
if (hits <= ctx.qry.ofs)
|
if (hits <= ctx.qry.ofs)
|
||||||
|
Loading…
Reference in New Issue
Block a user