From 65537ac1b41f18e029b8172b8308189434c310d6 Mon Sep 17 00:00:00 2001 From: Bruce Momjian Date: Thu, 2 Jun 2005 01:23:08 +0000 Subject: [PATCH] Add support for \x hex escapes in backend strings. Octal was already supported. This follows the C standard escapes. --- doc/src/sgml/syntax.sgml | 25 +++++++++++++------------ src/backend/parser/scan.l | 9 +++++++-- 2 files changed, 20 insertions(+), 14 deletions(-) diff --git a/doc/src/sgml/syntax.sgml b/doc/src/sgml/syntax.sgml index 6e49e9cee1..45b6a80564 100644 --- a/doc/src/sgml/syntax.sgml +++ b/doc/src/sgml/syntax.sgml @@ -1,5 +1,5 @@ @@ -254,17 +254,18 @@ UPDATE "my_table" SET "a" = 5; Another PostgreSQL extension is that - C-style backslash escapes are available: - \b is a backspace, \f is a - form feed, \n is a newline, - \r is a carriage return, \t - is a tab, and \xxx, - where xxx is an octal number, is a - byte with the corresponding code. (It is your responsibility - that the byte sequences you create are valid characters in the - server character set encoding.) Any other character following a - backslash is taken literally. Thus, to include a backslash in a - string constant, write two backslashes. + C-style backslash escapes are available: \b is a + backspace, \f is a form feed, + \n is a newline, \r is a + carriage return, \t is a tab. Also supported is + \digits, where + ddd represents an octal byte value, and + \xhexdigits, where + hexdigits represents a hexadecimal byte value. + (It is your responsibility that the byte sequences you create are + valid characters in the server character set encoding.) Any other + character following a backslash is taken literally. Thus, to + include a backslash in a string constant, write two backslashes. diff --git a/src/backend/parser/scan.l b/src/backend/parser/scan.l index ef5c1a639f..161a32861f 100644 --- a/src/backend/parser/scan.l +++ b/src/backend/parser/scan.l @@ -24,7 +24,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/parser/scan.l,v 1.122 2005/05/26 01:24:29 tgl Exp $ + * $PostgreSQL: pgsql/src/backend/parser/scan.l,v 1.123 2005/06/02 01:23:08 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -193,8 +193,9 @@ xnstart [nN]{quote} xqstart {quote} xqdouble {quote}{quote} xqinside [^\\']+ -xqescape [\\][^0-7] +xqescape [\\][^0-7x] xqoctesc [\\][0-7]{1,3} +xqhexesc [\\]x[0-9A-Fa-f]{1,2} /* $foo$ style quotes ("dollar quoting") * The quoted string starts with $foo$ where "foo" is an optional string @@ -435,6 +436,10 @@ other . unsigned char c = strtoul(yytext+1, NULL, 8); addlitchar(c); } +{xqhexesc} { + unsigned char c = strtoul(yytext+2, NULL, 16); + addlitchar(c); + } {quotecontinue} { /* ignore */ }