X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=src%2Fui%2Fgui%2Fhelper.c;h=d60a01ac12fce9092228675a20bedcce8fd837b1;hb=4f2f805c653f0dc901924944ea4c55309ff14d32;hp=549242e6f01a1b4b4bfc952a7965242a1f74b46c;hpb=573068f2bdcd3f8796e9646668fed910a90f890b;p=pspp-builds.git diff --git a/src/ui/gui/helper.c b/src/ui/gui/helper.c index 549242e6..d60a01ac 100644 --- a/src/ui/gui/helper.c +++ b/src/ui/gui/helper.c @@ -1,10 +1,15 @@ +#include #include "helper.h" #include +#include #include +#include + #include #include +#include /* Formats a value according to FORMAT The returned string must be freed when no longer required */ @@ -14,10 +19,7 @@ value_to_text(union value v, struct fmt_spec format) gchar *s = 0; s = g_new(gchar, format.w + 1); - if ( ! data_out(s, &format, &v) ) - { - g_warning("Can't format missing discrete value \n"); - } + data_out(&v, &format, s); s[format.w]='\0'; g_strchug(s); @@ -30,7 +32,7 @@ gboolean text_to_value(const gchar *text, union value *v, struct fmt_spec format) { - struct data_in di; + bool ok; if ( format.type != FMT_A) { @@ -49,15 +51,12 @@ text_to_value(const gchar *text, union value *v, } } - di.s = text; - di.e = text + strlen(text); - di.v = v; - di.flags = DI_IGNORE_ERROR; - di.f1 = di.f2 = 0; - di.format = format; - - return data_in(&di); + msg_disable (); + ok = data_in (ss_cstr (text), format.type, 0, 0, + v, fmt_var_width (&format)); + msg_enable (); + return ok; } @@ -71,8 +70,15 @@ get_widget_assert(GladeXML *xml, const gchar *name) w = glade_xml_get_widget(xml, name); if ( !w ) - g_warning("Widget \"%s\" could not be found\n",name); + g_warning("Widget \"%s\" could not be found\n", name); return w; } +/* Converts a string in the pspp locale to utf-8 */ +char * +pspp_locale_to_utf8(const gchar *text, gssize len, GError **err) +{ + return recode_string(CONV_PSPP_TO_UTF8, text, len); +} +