On Sat, Mar 31, 2007 at 07:47:21PM -0700, Mark Dilger wrote:
> OK, I can take a stab at fixing this. I'd like to state some assumptions
> so people can comment and reply:
> I assume that I need to fix *all* cases where invalid byte encodings get
> into the database through functions shipped in the core distribution.
> I assume I do not need to worry about people getting bad data into the
> system through their own database extensions.
That'd be rather difficult :)
> I assume that the COPY problem discussed up-thread goes away once you
> eliminate all the paths by which bad data can get into the system.
> However, existing database installations with bad data already loaded will
> not be magically fixed with these code patches.
> Do any of the string functions (see
> http://www.postgresql.org/docs/8.2/interactive/functions-string.html) run
> the risk of generating invalid utf8 encoded strings? Do I need to add
> checks? Are there known bugs with these functions in this regard?
I don't think so. They'd be bugs if they were...
> If not, I assume I can add mbverify calls to the various input routines
> (textin, varcharin, etc) where invalid utf8 could otherwise enter the
The only hard part is handling where the escaping and unescaping is
> I assume that this work can be limited to HEAD and that I don't need to
> back-patch it. (I suspect this assumption is a contentious one.)
At the very least I'd start with HEAD. Whether it gets backpatched
probably depends on how invasive it ends up being...
There's also the performance angle. The current mbverify is very
inefficient for encodings like UTF-8. You might need to refactor a bit
Have a nice day,
Martijn van Oosterhout <kleptog(at)svana(dot)org> http://svana.org/kleptog/
> From each according to his ability. To each according to his ability to litigate.
In response to
pgsql-hackers by date
|Next:||From: korryd||Date: 2007-04-01 12:23:12|
|Subject: Re: Last minute mini-proposal (I know, Iknow)forPQexecf()|
|Previous:||From: Peter Eisentraut||Date: 2007-04-01 10:04:06|
|Subject: Re: Macros for typtype (was Re: Arrays of Complex Types)|