-rw-r--r-- | cgit.c | 23 |
1 files changed, 20 insertions, 3 deletions
@@ -182,7 +182,12 @@ void config_cb(const char *name, const char *value) else if (!strcmp(name, "max-commit-count")) ctx.cfg.max_commit_count = atoi(value); + else if (!strcmp(name, "project-list")) + ctx.cfg.project_list = xstrdup(expand_macros(value)); else if (!strcmp(name, "scan-path")) if (!ctx.cfg.nocache && ctx.cfg.cache_size) process_cached_repolist(expand_macros(value)); + else if (ctx.cfg.project_list) + scan_projects(expand_macros(value), + ctx.cfg.project_list, repo_config); else scan_tree(expand_macros(value), repo_config); @@ -296,4 +301,5 @@ static void prepare_context(struct cgit_context *ctx) ctx->cfg.max_stats = 0; ctx->cfg.module_link = "./?repo=%s&page=commit&id=%s"; + ctx->cfg.project_list = NULL; ctx->cfg.renamelimit = -1; ctx->cfg.robots = "index, nofollow"; @@ -575,4 +581,7 @@ static int generate_cached_repolist(const char *path, const char *cached_rc) } idx = cgit_repolist.count; + if (ctx.cfg.project_list) + scan_projects(path, ctx.cfg.project_list, repo_config); + else scan_tree(path, repo_config); print_repolist(f, &cgit_repolist, idx); @@ -589,7 +598,10 @@ static void process_cached_repolist(const char *path) char *cached_rc; time_t age; + unsigned long hash; - cached_rc = xstrdup(fmt("%s/rc-%8x", ctx.cfg.cache_root, - hash_str(path))); + hash = hash_str(path); + if (ctx.cfg.project_list) + hash += hash_str(ctx.cfg.project_list); + cached_rc = xstrdup(fmt("%s/rc-%8x", ctx.cfg.cache_root, hash)); if (stat(cached_rc, &st)) { @@ -598,6 +610,11 @@ static void process_cached_repolist(const char *path) * invoke scan_tree manually. */ - if (generate_cached_repolist(path, cached_rc)) + if (generate_cached_repolist(path, cached_rc)) { + if (ctx.cfg.project_list) + scan_projects(path, ctx.cfg.project_list, + repo_config); + else scan_tree(path, repo_config); + } return; } |