Move function for configfile parsing into configfile.[ch]
This is a generic function which wanted its own little object file. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
		
							parent
							
								
									ee4056bd2c
								
							
						
					
					
						commit
						20a33548b9
					
				
							
								
								
									
										1
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Makefile
									
									
									
									
									
								
							| @ -51,6 +51,7 @@ OBJECTS = | |||||||
| OBJECTS += cache.o | OBJECTS += cache.o | ||||||
| OBJECTS += cgit.o | OBJECTS += cgit.o | ||||||
| OBJECTS += cmd.o | OBJECTS += cmd.o | ||||||
|  | OBJECTS += configfile.o | ||||||
| OBJECTS += html.o | OBJECTS += html.o | ||||||
| OBJECTS += parsing.o | OBJECTS += parsing.o | ||||||
| OBJECTS += shared.o | OBJECTS += shared.o | ||||||
|  | |||||||
							
								
								
									
										5
									
								
								cgit.c
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								cgit.c
									
									
									
									
									
								
							| @ -9,6 +9,7 @@ | |||||||
| #include "cgit.h" | #include "cgit.h" | ||||||
| #include "cache.h" | #include "cache.h" | ||||||
| #include "cmd.h" | #include "cmd.h" | ||||||
|  | #include "configfile.h" | ||||||
| #include "ui-shared.h" | #include "ui-shared.h" | ||||||
| 
 | 
 | ||||||
| const char *cgit_version = CGIT_VERSION; | const char *cgit_version = CGIT_VERSION; | ||||||
| @ -103,7 +104,7 @@ void config_cb(const char *name, const char *value) | |||||||
| 		else | 		else | ||||||
| 			ctx.repo->readme = xstrdup(fmt("%s/%s", ctx.repo->path, value)); | 			ctx.repo->readme = xstrdup(fmt("%s/%s", ctx.repo->path, value)); | ||||||
| 	} else if (!strcmp(name, "include")) | 	} else if (!strcmp(name, "include")) | ||||||
| 		cgit_read_config(value, config_cb); | 		parse_configfile(value, config_cb); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void querystring_cb(const char *name, const char *value) | static void querystring_cb(const char *name, const char *value) | ||||||
| @ -436,7 +437,7 @@ int main(int argc, const char **argv) | |||||||
| 	cgit_repolist.count = 0; | 	cgit_repolist.count = 0; | ||||||
| 	cgit_repolist.repos = NULL; | 	cgit_repolist.repos = NULL; | ||||||
| 
 | 
 | ||||||
| 	cgit_read_config(cgit_config_env ? cgit_config_env : CGIT_CONFIG, | 	parse_configfile(cgit_config_env ? cgit_config_env : CGIT_CONFIG, | ||||||
| 			 config_cb); | 			 config_cb); | ||||||
| 	if (getenv("SCRIPT_NAME")) | 	if (getenv("SCRIPT_NAME")) | ||||||
| 		ctx.cfg.script_name = xstrdup(getenv("SCRIPT_NAME")); | 		ctx.cfg.script_name = xstrdup(getenv("SCRIPT_NAME")); | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								cgit.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								cgit.h
									
									
									
									
									
								
							| @ -214,7 +214,6 @@ extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); | |||||||
| 
 | 
 | ||||||
| extern char *fmt(const char *format,...); | extern char *fmt(const char *format,...); | ||||||
| 
 | 
 | ||||||
| extern int cgit_read_config(const char *filename, configfn fn); |  | ||||||
| extern int cgit_parse_query(char *txt, configfn fn); | extern int cgit_parse_query(char *txt, configfn fn); | ||||||
| extern struct commitinfo *cgit_parse_commit(struct commit *commit); | extern struct commitinfo *cgit_parse_commit(struct commit *commit); | ||||||
| extern struct taginfo *cgit_parse_tag(struct tag *tag); | extern struct taginfo *cgit_parse_tag(struct tag *tag); | ||||||
|  | |||||||
							
								
								
									
										87
									
								
								configfile.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								configfile.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,87 @@ | |||||||
|  | /* configfile.c: parsing of config files
 | ||||||
|  |  * | ||||||
|  |  * Copyright (C) 2008 Lars Hjemli | ||||||
|  |  * | ||||||
|  |  * Licensed under GNU General Public License v2 | ||||||
|  |  *   (see COPYING for full license text) | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #include <ctype.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include "configfile.h" | ||||||
|  | 
 | ||||||
|  | int next_char(FILE *f) | ||||||
|  | { | ||||||
|  | 	int c = fgetc(f); | ||||||
|  | 	if (c=='\r') { | ||||||
|  | 		c = fgetc(f); | ||||||
|  | 		if (c!='\n') { | ||||||
|  | 			ungetc(c, f); | ||||||
|  | 			c = '\r'; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return c; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void skip_line(FILE *f) | ||||||
|  | { | ||||||
|  | 	int c; | ||||||
|  | 
 | ||||||
|  | 	while((c=next_char(f)) && c!='\n' && c!=EOF) | ||||||
|  | 		; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int read_config_line(FILE *f, char *line, const char **value, int bufsize) | ||||||
|  | { | ||||||
|  | 	int i = 0, isname = 0; | ||||||
|  | 
 | ||||||
|  | 	*value = NULL; | ||||||
|  | 	while(i<bufsize-1) { | ||||||
|  | 		int c = next_char(f); | ||||||
|  | 		if (!isname && (c=='#' || c==';')) { | ||||||
|  | 			skip_line(f); | ||||||
|  | 			continue; | ||||||
|  | 		} | ||||||
|  | 		if (!isname && isspace(c)) | ||||||
|  | 			continue; | ||||||
|  | 
 | ||||||
|  | 		if (c=='=' && !*value) { | ||||||
|  | 			line[i] = 0; | ||||||
|  | 			*value = &line[i+1]; | ||||||
|  | 		} else if (c=='\n' && !isname) { | ||||||
|  | 			i = 0; | ||||||
|  | 			continue; | ||||||
|  | 		} else if (c=='\n' || c==EOF) { | ||||||
|  | 			line[i] = 0; | ||||||
|  | 			break; | ||||||
|  | 		} else { | ||||||
|  | 			line[i]=c; | ||||||
|  | 		} | ||||||
|  | 		isname = 1; | ||||||
|  | 		i++; | ||||||
|  | 	} | ||||||
|  | 	line[i+1] = 0; | ||||||
|  | 	return i; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int parse_configfile(const char *filename, configfile_value_fn fn) | ||||||
|  | { | ||||||
|  | 	static int nesting; | ||||||
|  | 	int len; | ||||||
|  | 	char line[256]; | ||||||
|  | 	const char *value; | ||||||
|  | 	FILE *f; | ||||||
|  | 
 | ||||||
|  | 	/* cancel deeply nested include-commands */ | ||||||
|  | 	if (nesting > 8) | ||||||
|  | 		return -1; | ||||||
|  | 	if (!(f = fopen(filename, "r"))) | ||||||
|  | 		return -1; | ||||||
|  | 	nesting++; | ||||||
|  | 	while((len = read_config_line(f, line, &value, sizeof(line))) > 0) | ||||||
|  | 		fn(line, value); | ||||||
|  | 	nesting--; | ||||||
|  | 	fclose(f); | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
							
								
								
									
										8
									
								
								configfile.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								configfile.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | #ifndef CONFIGFILE_H | ||||||
|  | #define CONFIGFILE_H | ||||||
|  | 
 | ||||||
|  | typedef void (*configfile_value_fn)(const char *name, const char *value); | ||||||
|  | 
 | ||||||
|  | extern int parse_configfile(const char *filename, configfile_value_fn fn); | ||||||
|  | 
 | ||||||
|  | #endif /* CONFIGFILE_H */ | ||||||
							
								
								
									
										75
									
								
								parsing.c
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								parsing.c
									
									
									
									
									
								
							| @ -8,81 +8,6 @@ | |||||||
| 
 | 
 | ||||||
| #include "cgit.h" | #include "cgit.h" | ||||||
| 
 | 
 | ||||||
| int next_char(FILE *f) |  | ||||||
| { |  | ||||||
| 	int c = fgetc(f); |  | ||||||
| 	if (c=='\r') { |  | ||||||
| 		c = fgetc(f); |  | ||||||
| 		if (c!='\n') { |  | ||||||
| 			ungetc(c, f); |  | ||||||
| 			c = '\r'; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	return c; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void skip_line(FILE *f) |  | ||||||
| { |  | ||||||
| 	int c; |  | ||||||
| 
 |  | ||||||
| 	while((c=next_char(f)) && c!='\n' && c!=EOF) |  | ||||||
| 		; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int read_config_line(FILE *f, char *line, const char **value, int bufsize) |  | ||||||
| { |  | ||||||
| 	int i = 0, isname = 0; |  | ||||||
| 
 |  | ||||||
| 	*value = NULL; |  | ||||||
| 	while(i<bufsize-1) { |  | ||||||
| 		int c = next_char(f); |  | ||||||
| 		if (!isname && (c=='#' || c==';')) { |  | ||||||
| 			skip_line(f); |  | ||||||
| 			continue; |  | ||||||
| 		} |  | ||||||
| 		if (!isname && isspace(c)) |  | ||||||
| 			continue; |  | ||||||
| 
 |  | ||||||
| 		if (c=='=' && !*value) { |  | ||||||
| 			line[i] = 0; |  | ||||||
| 			*value = &line[i+1]; |  | ||||||
| 		} else if (c=='\n' && !isname) { |  | ||||||
| 			i = 0; |  | ||||||
| 			continue; |  | ||||||
| 		} else if (c=='\n' || c==EOF) { |  | ||||||
| 			line[i] = 0; |  | ||||||
| 			break; |  | ||||||
| 		} else { |  | ||||||
| 			line[i]=c; |  | ||||||
| 		} |  | ||||||
| 		isname = 1; |  | ||||||
| 		i++; |  | ||||||
| 	} |  | ||||||
| 	line[i+1] = 0; |  | ||||||
| 	return i; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| int cgit_read_config(const char *filename, configfn fn) |  | ||||||
| { |  | ||||||
| 	static int nesting; |  | ||||||
| 	int len; |  | ||||||
| 	char line[256]; |  | ||||||
| 	const char *value; |  | ||||||
| 	FILE *f; |  | ||||||
| 
 |  | ||||||
| 	/* cancel deeply nested include-commands */ |  | ||||||
| 	if (nesting > 8) |  | ||||||
| 		return -1; |  | ||||||
| 	if (!(f = fopen(filename, "r"))) |  | ||||||
| 		return -1; |  | ||||||
| 	nesting++; |  | ||||||
| 	while((len = read_config_line(f, line, &value, sizeof(line))) > 0) |  | ||||||
| 		(*fn)(line, value); |  | ||||||
| 	nesting--; |  | ||||||
| 	fclose(f); |  | ||||||
| 	return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| char *convert_query_hexchar(char *txt) | char *convert_query_hexchar(char *txt) | ||||||
| { | { | ||||||
| 	int d1, d2; | 	int d1, d2; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user