|
|
|
@ -25,6 +25,21 @@ void add_mimetype(const char *name, const char *value) |
|
|
|
|
item->util = xstrdup(value); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
struct cgit_filter *new_filter(const char *cmd, int extra_args) |
|
|
|
|
{ |
|
|
|
|
struct cgit_filter *f; |
|
|
|
|
|
|
|
|
|
if (!cmd || !cmd[0]) |
|
|
|
|
return NULL; |
|
|
|
|
|
|
|
|
|
f = xmalloc(sizeof(struct cgit_filter)); |
|
|
|
|
f->cmd = xstrdup(cmd); |
|
|
|
|
f->argv = xmalloc((2 + extra_args) * sizeof(char *)); |
|
|
|
|
f->argv[0] = f->cmd; |
|
|
|
|
f->argv[1] = NULL; |
|
|
|
|
return f; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void config_cb(const char *name, const char *value) |
|
|
|
|
{ |
|
|
|
|
if (!strcmp(name, "root-title")) |
|
|
|
@ -85,6 +100,8 @@ void config_cb(const char *name, const char *value) |
|
|
|
|
ctx.cfg.cache_static_ttl = atoi(value); |
|
|
|
|
else if (!strcmp(name, "cache-dynamic-ttl")) |
|
|
|
|
ctx.cfg.cache_dynamic_ttl = atoi(value); |
|
|
|
|
else if (!strcmp(name, "commit-filter")) |
|
|
|
|
ctx.cfg.commit_filter = new_filter(value, 0); |
|
|
|
|
else if (!strcmp(name, "embedded")) |
|
|
|
|
ctx.cfg.embedded = atoi(value); |
|
|
|
|
else if (!strcmp(name, "max-message-length")) |
|
|
|
@ -95,6 +112,8 @@ void config_cb(const char *name, const char *value) |
|
|
|
|
ctx.cfg.max_repo_count = atoi(value); |
|
|
|
|
else if (!strcmp(name, "max-commit-count")) |
|
|
|
|
ctx.cfg.max_commit_count = atoi(value); |
|
|
|
|
else if (!strcmp(name, "source-filter")) |
|
|
|
|
ctx.cfg.source_filter = new_filter(value, 1); |
|
|
|
|
else if (!strcmp(name, "summary-log")) |
|
|
|
|
ctx.cfg.summary_log = atoi(value); |
|
|
|
|
else if (!strcmp(name, "summary-branches")) |
|
|
|
@ -139,6 +158,10 @@ void config_cb(const char *name, const char *value) |
|
|
|
|
ctx.repo->max_stats = cgit_find_stats_period(value, NULL); |
|
|
|
|
else if (ctx.repo && !strcmp(name, "repo.module-link")) |
|
|
|
|
ctx.repo->module_link= xstrdup(value); |
|
|
|
|
else if (ctx.repo && !strcmp(name, "repo.commit-filter")) |
|
|
|
|
ctx.repo->commit_filter = new_filter(value, 0); |
|
|
|
|
else if (ctx.repo && !strcmp(name, "repo.source-filter")) |
|
|
|
|
ctx.repo->source_filter = new_filter(value, 1); |
|
|
|
|
else if (ctx.repo && !strcmp(name, "repo.readme") && value != NULL) { |
|
|
|
|
if (*value == '/') |
|
|
|
|
ctx.repo->readme = xstrdup(value); |
|
|
|
|