X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Flexer%2Fvalue-parser.c;h=4ef092de3a3e6c884e3c236e2d159b19023eed01;hb=refs%2Fbuilds%2F20101125030504%2Fpspp;hp=c492658e28753ba5e3a9fe7780abf9a2fc7ba12c;hpb=d775f576e4ffc0973c5f183b57b2baa089f555dc;p=pspp diff --git a/src/language/lexer/value-parser.c b/src/language/lexer/value-parser.c index c492658e28..4ef092de3a 100644 --- a/src/language/lexer/value-parser.c +++ b/src/language/lexer/value-parser.c @@ -100,12 +100,16 @@ parse_number (struct lexer *lexer, double *x, const enum fmt_type *format) lex_get (lexer); return true; } - else if (lex_token (lexer) == T_STRING && format != NULL) + else if (lex_is_string (lexer) && format != NULL) { union value v; - assert (! (fmt_get_category (*format) & ( FMT_CAT_STRING ))); - data_in (ds_ss (lex_tokstr (lexer)), LEGACY_NATIVE, - *format, 0, 0, 0, NULL, &v, 0); + + assert (fmt_get_category (*format) != FMT_CAT_STRING); + + if (!data_in_msg (lex_tokss (lexer), LEGACY_NATIVE, + *format, &v, 0, NULL)) + return false; + lex_get (lexer); *x = v.f; if (*x == SYSMIS) @@ -139,7 +143,12 @@ parse_value (struct lexer *lexer, union value *v, int width) } else if (lex_force_string (lexer)) { - const char *s = ds_cstr (lex_tokstr (lexer)); + const char *s; + + if (!lex_force_string (lexer)) + return false; + + s = lex_tokcstr (lexer); value_copy_str_rpad (v, width, CHAR_CAST_BUG (const uint8_t *, s), ' '); } else