X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Flexer%2Fvalue-parser.c;h=23b4def274cc71191dd3d1018625766500b753eb;hb=409dfe7159b9b0fd96c67cfddd4ffa93e05aa9b2;hp=cc73176a38db24f2c0b940666d71b277943db23d;hpb=a6f1c88d9d4dee24e1f79048c8a5d8274f68c405;p=pspp diff --git a/src/language/lexer/value-parser.c b/src/language/lexer/value-parser.c index cc73176a38..23b4def274 100644 --- a/src/language/lexer/value-parser.c +++ b/src/language/lexer/value-parser.c @@ -96,19 +96,14 @@ parse_num_range (struct lexer *lexer, static bool parse_number (struct lexer *lexer, double *x, const enum fmt_type *format) { - if (lex_is_number (lexer)) - { - *x = lex_number (lexer); - lex_get (lexer); - return true; - } - else if (lex_is_string (lexer) && format != NULL) + if (lex_is_string (lexer) && format != NULL) { union value v; assert (fmt_get_category (*format) != FMT_CAT_STRING); - if (!data_in_msg (lex_tokss (lexer), "UTF-8", *format, &v, 0, NULL)) + if (!data_in_msg (lex_tokss (lexer), "UTF-8", *format, + settings_get_fmt_settings (), &v, 0, NULL)) return false; lex_get (lexer); @@ -120,14 +115,15 @@ parse_number (struct lexer *lexer, double *x, const enum fmt_type *format) } return true; } - else + + if (lex_force_num (lexer)) { - if (format != NULL) - lex_error (lexer, _("expecting number or data string")); - else - lex_force_num (lexer); - return false; + *x = lex_number (lexer); + lex_get (lexer); + return true; } + + return false; } /* Parses the current token from LEXER into value V, which must already have