From ffab7ee68b32d44ae2f35f688f417cd0109b0b45 Mon Sep 17 00:00:00 2001 From: Thomas Guyot-Sionnest Date: Sat, 15 Mar 2008 16:17:49 +0000 Subject: Fix segfault in test_ini.c and uncomment the affected tests Fix bug in stanza parsing where full section could be skipped Fix single-argument options git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1946 f882894a-f735-0410-b71e-b25c423dba1c --- lib/parse_ini.c | 25 ++++++++++++++++++------- 1 file changed, 18 insertions(+), 7 deletions(-) (limited to 'lib/parse_ini.c') diff --git a/lib/parse_ini.c b/lib/parse_ini.c index c915d795..b555316e 100644 --- a/lib/parse_ini.c +++ b/lib/parse_ini.c @@ -85,14 +85,14 @@ np_arg_list* np_get_defaults(const char *locator, const char *default_section){ /* if a file was specified or if we're using the default file */ if(i.file != NULL && strlen(i.file) > 0){ if(strcmp(i.file, "-")==0){ - inifile=stdout; + inifile=stdout; /* FIXME: Shouldn't it be 'stdin' ??? */ } else { inifile=fopen(i.file, "r"); } if(inifile==NULL) die(STATE_UNKNOWN, _("Config file error")); defaults=read_defaults(inifile, i.stanza); free(i.file); - if(inifile!=stdout) fclose(inifile); + if(inifile!=stdout) fclose(inifile); /* FIXME: Shouldn't it be 'stdin' ??? */ } free(i.stanza); return defaults; @@ -126,9 +126,9 @@ static np_arg_list* read_defaults(FILE *f, const char *stanza){ stanzastate=WRONGSTANZA; for(i=0; iarg=(char *)malloc(cfg_len+1); - strncpy(&optnew->arg[read_pos], "--", 2); read_pos+=2; + /* 1-character params needs only one dash */ + if (opt_len==1) { + strncpy(&optnew->arg[read_pos], "-", 1); + read_pos+=1; + } else { + strncpy(&optnew->arg[read_pos], "--", 2); + read_pos+=2; + } strncpy(&optnew->arg[read_pos], optptr, opt_len); read_pos+=opt_len; if(equals) optnew->arg[read_pos++]='='; if(value) { -- cgit v1.2.3