diff options
| author | Lars Hjemli <hjemli@gmail.com> | 2007-05-14 23:40:33 +0200 | 
|---|---|---|
| committer | Lars Hjemli <hjemli@gmail.com> | 2007-05-14 23:40:33 +0200 | 
| commit | 5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39 (patch) | |
| tree | 5c844c0ba53cfd2e838368ffbbd4583ac63d3608 /parsing.c | |
| parent | Let makefile override the configfile location (diff) | |
| download | cgit-5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39.tar.gz cgit-5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39.tar.bz2 cgit-5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39.zip | |
Add include-parameter to config files
This parameter can be used to include another config-file, like
a standalone repository listing.
Suggested in a patch by Kristian Høgsberg <krh@bitplanet.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to '')
| -rw-r--r-- | parsing.c | 14 | 
1 files changed, 8 insertions, 6 deletions
| @@ -64,19 +64,21 @@ int read_config_line(FILE *f, char *line, const char **value, int bufsize)  int cgit_read_config(const char *filename, configfn fn)  { -	int ret = 0, len; +	static int nesting; +	int len;  	char line[256];  	const char *value; -	FILE *f = fopen(filename, "r"); +	FILE *f; -	if (!f) +	/* cancel the reading of yet another configfile after 16 invocations */ +	if (nesting++ > 16) +		return -1; +	if (!(f = fopen(filename, "r")))  		return -1; -  	while((len = read_config_line(f, line, &value, sizeof(line))) > 0)  		(*fn)(line, value); -  	fclose(f); -	return ret; +	return 0;  }  char *convert_query_hexchar(char *txt) | 
