From 93eae1c206796d76e930c0c4860e4ead9c8fca14 Mon Sep 17 00:00:00 2001 From: gramanas Date: Sun, 29 Apr 2018 21:36:52 +0300 Subject: linkin park --- src/confparser.c | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) (limited to 'src/confparser.c') diff --git a/src/confparser.c b/src/confparser.c index 0f193e0..80120c8 100644 --- a/src/confparser.c +++ b/src/confparser.c @@ -43,7 +43,7 @@ int read_next_line(char *line, FILE *f) { } ConfVar match_variables(char *line, char matched[]) { - if (line[0] == '#' || util_is_str_empty(line)) { + if (line[0] == '#' || str_is_empty(line)) { return CV_NO_VAL_OR_COMMENT; } #define X(var, str, name) \ @@ -74,7 +74,7 @@ ConfigParserResult parse(Conf *conf, UserOpt *opt) { int flag = 1; char line[STR_L]; char matched[STR_L]; - while (read_next_line(line, confPtr)) { + while (read_next_line(line, confPtr) == 0) { if (strlen(line) > STR_L) { return CPR_WRONG_CONFIG; } @@ -84,7 +84,6 @@ ConfigParserResult parse(Conf *conf, UserOpt *opt) { conf->var = malloc(strlen(matched)+1); \ strcpy(conf->var, matched); \ if (!util_is_dir(matched)) { \ - free(conf->var); \ return CPR_WRONG_##var; \ } \ break; @@ -111,9 +110,10 @@ int config_file_parse(Conf *conf, UserOpt *opt) { switch (parse(conf, opt)) { #define X(var,str,name) \ case CPR_WRONG_##var: \ - printf("Config error:\n" \ + printf("--[ Config error ]--\n" \ "%s: %s\n" \ "defined in config does not exist\n", name, conf->var); \ + free(conf->var); \ return 0; \ break; CONFIG_VARIABLES_TABLE @@ -128,6 +128,15 @@ int config_file_parse(Conf *conf, UserOpt *opt) { } } +void free_conf(Conf *conf) { + if (conf->VC_dir) { + free(conf->VC_dir); + } + if (conf->SCRT_dir) { + free(conf->SCRT_dir); + } +} + int init_create_config_file(UserOpt *opt) { char tmp[200]; if (!util_file_exists(opt->argv[0])) { -- cgit v1.2.3