X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Flexer%2Fvalue-parser.c;h=6fa4319a6584fdedda62f9df0532e08385e416a0;hb=774441e68b4d2e3a4b5c6975e9614dcd4369955e;hp=c780d86f04e95429bad3ee1004bbf2021ab89884;hpb=a5097a183f00ab2d2dc538ba7094a4696e2fea04;p=pspp
diff --git a/src/language/lexer/value-parser.c b/src/language/lexer/value-parser.c
index c780d86f04..6fa4319a65 100644
--- a/src/language/lexer/value-parser.c
+++ b/src/language/lexer/value-parser.c
@@ -1,5 +1,5 @@
/* PSPP - a program for statistical analysis.
- Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc.
+ Copyright (C) 2005, 2006, 2009, 2010 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -15,14 +15,18 @@
along with this program. If not, see . */
#include
+
#include "value-parser.h"
+
#include
-#include
-#include
-#include "lexer.h"
-#include
-#include
-#include
+
+#include "data/data-in.h"
+#include "data/format.h"
+#include "data/value.h"
+#include "language/lexer/lexer.h"
+#include "libpspp/cast.h"
+#include "libpspp/message.h"
+#include "libpspp/str.h"
#include "gettext.h"
#define _(msgid) gettext (msgid)
@@ -96,7 +100,7 @@ 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 )));
@@ -133,12 +137,13 @@ parse_value (struct lexer *lexer, union value *v, int width)
return false;
v->f = lex_tokval (lexer);
}
- else
+ else if (lex_force_string (lexer))
{
- if (!lex_force_string (lexer))
- return false;
- value_copy_str_rpad (v, width, ds_cstr (lex_tokstr (lexer)), ' ');
+ const char *s = ds_cstr (lex_tokstr (lexer));
+ value_copy_str_rpad (v, width, CHAR_CAST_BUG (const uint8_t *, s), ' ');
}
+ else
+ return false;
lex_get (lexer);