From: | "Jeff Urlwin" <jurlwin(at)bellatlantic(dot)net> |
---|---|
To: | "Tim Bunce" <Tim(dot)Bunce(at)pobox(dot)com>, "David Wheeler" <david(at)wheeler(dot)net> |
Cc: | "Jeff Urlwin" <jurlwin(at)bellatlantic(dot)net>, <dbi-dev(at)perl(dot)org>, <pgsql-interfaces(at)postgresql(dot)org> |
Subject: | Re: :PgSQL: More Queestions |
Date: | 2002-11-21 23:05:42 |
Message-ID: | OEEMJFLOJPABMFADAPIKGEEEEDAA.jurlwin@bellatlantic.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-interfaces |
>
> On Wed, Nov 20, 2002 at 10:30:00PM -0800, David Wheeler wrote:
> > On Wednesday, November 20, 2002, at 06:53 AM, Tim Bunce wrote:
> >
> > >>But if I change it (as I'm seriously considering, in light of
> > >>PostgreSQL 7.3's support for prepared statements), I'll probably do no
> > >>parsing for comments.
> > >
> > >I think that would be a bad move.
> >
> > Yes, your last post makes very clear why. Thanks.
> >
> > >If it's seen the start of a string ("..." or '...') then it just
> > >keeps copying the string till it finds the same type of quote
> > >character to mark the end of the string. The 'fiddly bit in the
> > >middle' is handling backslashes used to escape quote chars in the
> > >middle of the string: "...\"..." and "...\\" (odd vs even number).
> >
> > Seems rather opaque. Maybe I'm just reflecting my C-newbieness, but why
> > wouldn't this work as well? Borrowing a bit from DBD::ODBC here (but
> > allowing for both kinds of escaping of the quote characters):
> >
> > if (*src == '"' || *src == '\'') {
> > if (!in_literal) {
> > literal_ch = *src;
> > in_literal = 1;
>
> No need for in_literal as literal_ch can serve as a flag as well.
True...I was hacking that in and overlooked it.
>
> > } else {
> > if (*src == literal_ch && *(src-1) != '//'
> > && *(src-1) != literal_ch) {
> > in_literal = 0;
> > }
> > }
> > }
>
> Can't distinguish between
> "....\\\\" - final double quote ends the string
> "...\\\\\" - final double quote is escaped and string
> continues...
>
> If the original code isn't broken it doesn't need fixing, maybe
> just commenting.
I'm tempted to leave it, since nobody is complaining, at the moment...but
I'll put it on the list.
Jeff
From | Date | Subject | |
---|---|---|---|
Next Message | David Wheeler | 2002-11-21 23:38:43 | Re: DBD::PostgreSQL compile time /run time version |
Previous Message | Rudy Lippan | 2002-11-21 20:54:56 | Re: :PgSQL: More Queestions |