in reply to UTF8 fun and games again

The problem seems to be in some of the code you don't show, the code that talks to the database. It's a bit hard to debug that.

Please read and understand this post, it will help you with your issue.

Replies are listed 'Best First'.
Re^2: UTF8 fun and games again
by ultranerds (Hermit) on Oct 17, 2011 at 18:13 UTC
    Hi,

    Thanks for the reply. Here is the full test script:

    #!/usr/bin/perl use strict; use lib './'; use Links qw/$IN $DB $CFG $USER/; use CGI::Carp qw(fatalsToBrowser); use JSON; use Unicode::String qw(latin1 utf8); use LWP::UserAgent; print "Content-Type: text/html \n\n"; my $key = 'xxxx'; my $string = Do_Translate("en","fr",'are you'); $DB->table('Links')->update( { Title => "êtes-vous" } , { ID => 32 +902 } ) || die $GT::SQL::error; # works $DB->table('Links')->update( { Title => $string } , { ID => 32902 +} ) || die $GT::SQL::error; # doesnt work sub Do_Translate { my ($from,$to,$string) = @_; my $url = "https://www.googleapis.com/language/translate/v2?key=$k +ey&q=$string&source=$from&target=$to"; my $ua = LWP::UserAgent->new(); my $body = $ua->get($url); my $json = from_json($body->decoded_content); use Data::Dumper; print Dumper($json); print "GOT: $json->{data}->{translations}[0]->{translatedText} \n" +; return utf8($json->{data}->{translations}[0]->{translatedText})->l +atin1; }


    Just gonna take a look at that link too

    Cheers

    Andy
        Hi,

        I can't post that code, as its all over the place (part of the API for the database in the script I'm using). I know that code works fine normally, as I've used UTF8 charachters loads). The problem has to be something to do with this code.
        If I do:
        my $string = Do_Translate("en","fr",'are you'); use Data::Dumper; print Dumper($string,'êtes-vous');


        I see:

        $VAR1 = 'êtes-vous'; $VAR2 = "\x{ad25}s-vous";


        Argh its driving me up the wall!

        BTW, here is the actual JSON data thats getting passed back:

        'translations' => [ { 'translatedText' => "\x{c3 +}\x{aa}tes-vous" } ]