X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Fexpressions%2Foperations.def;h=5d1ee46e9d2439b7a9409f7b9462b2bc70e9430e;hb=48e0129f54424a6fd5fb1bc7651e48dedc5293c2;hp=844cab7e17ed133393d983bc02e6bf606b96ea4e;hpb=ebd0dcdfe65da02a6e541ceea0226c9b0b8d7a47;p=pspp diff --git a/src/language/expressions/operations.def b/src/language/expressions/operations.def index 844cab7e17..5d1ee46e9d 100644 --- a/src/language/expressions/operations.def +++ b/src/language/expressions/operations.def @@ -581,7 +581,19 @@ string function RTRIM (string s, string c) function NUMBER (string s, ni_format f) { union value out; - data_in (ss_head (s, f->w), LEGACY_NATIVE, f->type, f->d, 0, 0, NULL, &out, 0); + char *error; + + if (s.length > f->w) + s.length = f->w; + error = data_in (s, LEGACY_NATIVE, f->type, &out, 0, NULL); + if (error == NULL) + data_in_imply_decimals (s, LEGACY_NATIVE, f->type, f->d, &out); + else + { + msg (SE, "Cannot parse `%.*s' as format %s: %s", + (int) s.length, s.string, fmt_name (f->type), error); + free (error); + } return out.f; } @@ -961,7 +973,8 @@ absorb_miss no_opt string operator VEC_ELEM_STR (idx) if (idx >= 1 && idx <= vector_get_var_cnt (v)) { struct variable *var = vector_get_var (v, (size_t) idx - 1); - return copy_string (e, case_str (c, var), var_get_width (var)); + return copy_string (e, CHAR_CAST_BUG (char *, case_str (c, var)), + var_get_width (var)); } else { @@ -1029,7 +1042,8 @@ no_opt perm_only string function LAG (str_var v, pos_int n_before) { const struct ccase *c = lagged_case (ds, n_before); if (c != NULL) - return copy_string (e, case_str (c, v), var_get_width (v)); + return copy_string (e, CHAR_CAST_BUG (char *, case_str (c, v)), + var_get_width (v)); else return empty_string; } @@ -1040,7 +1054,8 @@ no_opt perm_only string function LAG (str_var v) { const struct ccase *c = lagged_case (ds, 1); if (c != NULL) - return copy_string (e, case_str (c, v), var_get_width (v)); + return copy_string (e, CHAR_CAST_BUG (char *, case_str (c, v)), + var_get_width (v)); else return empty_string; }