X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fhelper.c;h=d60a01ac12fce9092228675a20bedcce8fd837b1;hb=480a0746507ce73d26f528b56dc3ed80195096e0;hp=b3d83da270472ea6b62cf3d2ea1405d82870b727;hpb=a19b858e0ac3c69e4a28c0ca6d8674427268a863;p=pspp-builds.git diff --git a/src/ui/gui/helper.c b/src/ui/gui/helper.c index b3d83da2..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,45 +32,53 @@ 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) { if ( ! text ) return FALSE; - - const gchar *s = text; - while(*s) - { - if ( !isspace(*s)) - break; - s++; - } + + { + const gchar *s = text; + while(*s) + { + if ( !isspace(*s)) + break; + s++; + } - if ( !*s) return FALSE; + if ( !*s) return FALSE; + } } - 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; } GtkWidget * get_widget_assert(GladeXML *xml, const gchar *name) { + GtkWidget *w; g_assert(xml); g_assert(name); - GtkWidget * w = glade_xml_get_widget(xml, 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); +} +