X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?p=pspp-builds.git;a=blobdiff_plain;f=src%2Fui%2Fgui%2Fhelper.c;h=b09a2f58c3f1cc7bff73e36aecbb4775a81c1049;hp=ff750b25f7aa6ffe3b6a99e55a2d014791bcf5d8;hb=d8659cda7d193dd3e6e035cd0b1b40493d360f0b;hpb=04b418d95b3a0394fc7726087be7fa331d98b944 diff --git a/src/ui/gui/helper.c b/src/ui/gui/helper.c index ff750b25..b09a2f58 100644 --- a/src/ui/gui/helper.c +++ b/src/ui/gui/helper.c @@ -60,17 +60,27 @@ value_to_text (union value v, const PsppireDict *dict, struct fmt_spec format) } +/* Converts TEXT to a value. -gboolean -text_to_value (const gchar *text, union value *v, + VAL will be initialised and filled by this function. + It is the caller's responsibility to destroy VAL when no longer needed. + VAR and DICT must be the variable and dictionary with which VAL + is associated. + + On success, VAL is returned, NULL otherwise. +*/ +union value * +text_to_value (const gchar *text, const PsppireDict *dict, - struct fmt_spec format) + const struct variable *var, + union value *val) { - bool ok; + const struct fmt_spec *format = var_get_print_format (var); + int width = var_get_width (var); - if ( format.type != FMT_A) + if ( format->type != FMT_A) { - if ( ! text ) return FALSE; + if ( ! text ) return NULL; { const gchar *s = text; @@ -81,17 +91,18 @@ text_to_value (const gchar *text, union value *v, s++; } - if ( !*s) return FALSE; + if ( !*s) return NULL; } } + value_init (val, width); msg_disable (); - ok = data_in (ss_cstr (text), UTF8, format.type, 0, 0, 0, + data_in (ss_cstr (text), UTF8, format->type, 0, 0, 0, dict->dict, - v, fmt_var_width (&format)); + val, width); msg_enable (); - return ok; + return val; }