]> granicus.if.org Git - postgresql/commit
Plug some more holes in encoding conversion.
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 23 Feb 2014 20:22:50 +0000 (15:22 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 23 Feb 2014 20:22:50 +0000 (15:22 -0500)
commit49c817eab78c6f0ce8c3bf46766b73d6cf3190b7
tree546acfbda38b8c866dc86e9748de07101c089951
parent2c65856b7b444a5e804d4f694438e7444811d26b
Plug some more holes in encoding conversion.

Various places assume that pg_do_encoding_conversion() and
pg_server_to_any() will ensure encoding validity of their results;
but they failed to do so in the case that the source encoding is SQL_ASCII
while the destination is not.  We cannot perform any actual "conversion"
in that scenario, but we should still validate the string according to the
destination encoding.  Per bug #9210 from Digoal Zhou.

Arguably this is a back-patchable bug fix, but on the other hand adding
more enforcing of encoding checks might break existing applications that
were being sloppy.  On balance there doesn't seem to be much enthusiasm
for a back-patch, so fix in HEAD only.

While at it, remove some apparently-no-longer-needed provisions for
letting pg_do_encoding_conversion() "work" outside a transaction ---
if you consider it "working" to silently fail to do the requested
conversion.

Also, make a few cosmetic improvements in mbutils.c, notably removing
some Asserts that are certainly dead code since the variables they
assert aren't null are never null, even at process start.  (I think
this wasn't true at one time, but it is now.)
src/backend/utils/mb/mbutils.c