diff --git a/src/lib66/parser_enabled.c b/src/lib66/parser_enabled.c index efc5ab9a9c615e82043ad552d05a9095c39cb91e..4866a54abc12fc020f6811463537d02cee9df7f1 100644 --- a/src/lib66/parser_enabled.c +++ b/src/lib66/parser_enabled.c @@ -141,6 +141,8 @@ int parse_service_before(ssexec_t *info,stralloc *parsed_list, char const *sv,un else if (!r) return 0 ; sv_alltype sv_before = SV_ALLTYPE_ZERO ; + sasv->len = 0 ; + insta = instance_check(svname) ; if (!insta) { diff --git a/src/lib66/parser_utils.c b/src/lib66/parser_utils.c index 9784969ee46aaa126f4ccc49ea9ebe099795be68..2b6cd8fdad0f5f4a7b7464bb1290aeab76a738e0 100644 --- a/src/lib66/parser_utils.c +++ b/src/lib66/parser_utils.c @@ -146,7 +146,9 @@ int section_get_range(section_t *sasection,stralloc *src) wild_zero_all(&MILL_GET_SECTION_NAME) ; r = mill_string(&cp,src,&MILL_GET_LINE) ; if (r == -1 || !r) goto err ; - if (!sastr_rebuild_in_nline(&cp)) goto err ; + if (!sastr_rebuild_in_nline(&cp) || + !stralloc_0(&cp)) goto err ; + while (pos < cp.len) { if(secname.len && n) @@ -829,7 +831,6 @@ int read_svfile(stralloc *sasv,char const *name,char const *src) VERBO3 strerr_warnw2x(svtmp," is empty") ; return 0 ; } - sasv->len = 0 ; r = openreadfileclose(svtmp,sasv,filesize) ; if(!r)