XML::Parser requires an XML document. It honours BOMs and the encoding attribute. I confirmed this by testing.
But you don't pass it an XML document. An XML document is a collection of bytes, but you decoded the XML document into characters. It's the parser's job to decode the values it returns using the encoding specified inside the document, so you need to avoid removing any character encoding. Fix:
# Remove Content-Encoding (e.g. compression), # but leave document as bytes. my $xml = $response->decoded_content( charset => 'none' );
Why did your code work if it was buggy? Because there's also a bug in XML::Parser::Expat. Expat incorrectly uses Perl's internal representation of the string as the XML document instead of using the contents of the string. Most of the time, your bug and this bug cancel out to produce the right output.
Here's the workaround for the bug in XML::Expat (does nothing most of the time):
# Expat expects the string to use this internal format. utf8::downgrade($xml) if $] ge '5.008'; $p->parse($xml);
In reply to Re: LWP::Agent vs. XML::Parser - the zillionth encoding madness question
by ikegami
in thread LWP::Agent vs. XML::Parser - the zillionth encoding madness question
by .rhavin
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |