From b51366396b0e150c18ea62006b24a610c5a7f8d8 Mon Sep 17 00:00:00 2001 From: Bruce Momjian Date: Thu, 2 Jun 2005 01:23:48 +0000 Subject: [PATCH] Add support for \x hex strings in psql variables. --- doc/src/sgml/ref/psql-ref.sgml | 7 ++++--- src/bin/psql/psqlscan.l | 14 ++++++++++++-- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/doc/src/sgml/ref/psql-ref.sgml b/doc/src/sgml/ref/psql-ref.sgml index 55c160e91c..bc762ab7c1 100644 --- a/doc/src/sgml/ref/psql-ref.sgml +++ b/doc/src/sgml/ref/psql-ref.sgml @@ -1,5 +1,5 @@ @@ -589,8 +589,9 @@ testdb=> single quote. To include a single quote into such an argument, precede it by a backslash. Anything contained in single quotes is furthermore subject to C-like substitutions for - \n (new line), \t (tab), and - \digits (octal). + \n (new line), \t (tab), + \digits (octal), + \xdigits (hexadecimal). diff --git a/src/bin/psql/psqlscan.l b/src/bin/psql/psqlscan.l index 4159ee0220..d0e1dc80d2 100644 --- a/src/bin/psql/psqlscan.l +++ b/src/bin/psql/psqlscan.l @@ -33,7 +33,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $PostgreSQL: pgsql/src/bin/psql/psqlscan.l,v 1.12 2005/05/30 16:48:47 momjian Exp $ + * $PostgreSQL: pgsql/src/bin/psql/psqlscan.l,v 1.13 2005/06/02 01:23:48 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -250,8 +250,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 @@ -467,6 +468,9 @@ other . {xqoctesc} { ECHO; } +{xqhexesc} { + ECHO; + } {quotecontinue} { ECHO; } @@ -855,6 +859,12 @@ other . (char) strtol(yytext + 1, NULL, 8)); } +{xqhexesc} { + /* hex case */ + appendPQExpBufferChar(output_buf, + (char) strtol(yytext + 2, NULL, 16)); + } + "\\". { emit(yytext + 1, 1); } {other}|\n { ECHO; } -- 2.40.0