universal parser: do not leak parser->data
authorDenys Vlasenko <vda.linux@googlemail.com>
Sat, 26 Jun 2010 02:00:52 +0000 (04:00 +0200)
committerDenys Vlasenko <vda.linux@googlemail.com>
Sat, 26 Jun 2010 02:00:52 +0000 (04:00 +0200)
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
libbb/parse_config.c

index c511d97fbd60aa913000d6a42501100ceadf5f95..b7c3a00e0670f43d240c8a4d337b2669bcb92f0d 100644 (file)
@@ -128,8 +128,8 @@ int FAST_FUNC config_read(parser_t *parser, char **tokens, unsigned flags, const
        int ntokens, mintokens;
        int t, len;
 
-       ntokens = flags & 0xFF;
-       mintokens = (flags & 0xFF00) >> 8;
+       ntokens = (uint8_t)flags;
+       mintokens = (uint8_t)(flags >> 8);
 
        if (parser == NULL)
                return 0;
@@ -159,7 +159,8 @@ again:
                parser->data = xstrdup(line);
 
        /* Tokenize the line */
-       for (t = 0; *line && *line != delims[0] && t < ntokens; t++) {
+       t = 0;
+       do {
                /* Pin token */
                tokens[t] = line;
 
@@ -179,10 +180,10 @@ again:
                }
 
                /* Token not terminated? */
-               if (line[0] == delims[0])
+               if (*line == delims[0])
                        *line = '\0';
-               else if (line[0] != '\0')
-                       *(line++) = '\0';
+               else if (*line != '\0')
+                       *line++ = '\0';
 
 #if 0 /* unused so far */
                if (flags & PARSE_ESCAPE) {
@@ -201,17 +202,20 @@ again:
                        *to = '\0';
                }
 #endif
-
                /* Skip possible delimiters */
                if (flags & PARSE_COLLAPSE)
                        line += strspn(line, delims + 1);
-       }
+
+               t++;
+       } while (*line && *line != delims[0] && t < ntokens);
 
        if (t < mintokens) {
                bb_error_msg("bad line %u: %d tokens found, %d needed",
                                parser->lineno, t, mintokens);
                if (flags & PARSE_MIN_DIE)
                        xfunc_die();
+               if (flags & PARSE_KEEP_COPY)
+                       free(parser->data);
                goto again;
        }