=?UTF-8?Q?=c3=81lvaro_Hern=c3=a1ndez_Tortosa?= <a...@8kdata.com> writes: > According to https://en.wikipedia.org/wiki/UTF-8#Codepage_layout > the encoding used in Modified UTF-8 is an (otherwise) invalid UTF-8 code > point. In short, the \u00 nul is represented (overlong encoding) by the > two-byte, 1 character sequence \uc080. These two bytes are invalid UTF-8 > so should not appear in an otherwise valid UTF-8 string. Yet they are > accepted by Postgres (like if Postgres would support Modified UTF-8 > intentionally).
Really? It sure looks to me like pg_utf8_islegal() would reject this. We could hack it to allow the case, no doubt, but I concur with Peter's concern that we'd have trouble with OS-level code that is strict about what UTF8 allows. glibc, for example, is known to do very strange things with strings that it thinks are invalid in the active encoding. regards, tom lane -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers