diff options
Diffstat (limited to '')
| -rw-r--r-- | cgit.c | 23 | 
1 files changed, 23 insertions, 0 deletions
| @@ -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); | 
