mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-06 15:24:56 +08:00
Add code to pg_dump to use E'' strings when backslashes are used in dump
files.
This commit is contained in:
parent
975368e267
commit
539bc9fc91
@ -7,7 +7,7 @@
|
|||||||
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
|
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
|
||||||
* Portions Copyright (c) 1994, Regents of the University of California
|
* Portions Copyright (c) 1994, Regents of the University of California
|
||||||
*
|
*
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/dumputils.c,v 1.17 2005/04/30 08:08:51 neilc Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/dumputils.c,v 1.18 2005/07/01 21:03:25 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -111,6 +111,27 @@ fmtId(const char *rawid)
|
|||||||
void
|
void
|
||||||
appendStringLiteral(PQExpBuffer buf, const char *str, bool escapeAll)
|
appendStringLiteral(PQExpBuffer buf, const char *str, bool escapeAll)
|
||||||
{
|
{
|
||||||
|
bool has_escapes = false;
|
||||||
|
const char *str2 = str;
|
||||||
|
|
||||||
|
while (*str2)
|
||||||
|
{
|
||||||
|
char ch = *str2++;
|
||||||
|
|
||||||
|
if (ch == '\\' ||
|
||||||
|
((unsigned char) ch < (unsigned char) ' ' &&
|
||||||
|
(escapeAll ||
|
||||||
|
(ch != '\t' && ch != '\n' && ch != '\v' &&
|
||||||
|
ch != '\f' && ch != '\r'))))
|
||||||
|
{
|
||||||
|
has_escapes = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (has_escapes)
|
||||||
|
appendPQExpBufferChar(buf, 'E');
|
||||||
|
|
||||||
appendPQExpBufferChar(buf, '\'');
|
appendPQExpBufferChar(buf, '\'');
|
||||||
while (*str)
|
while (*str)
|
||||||
{
|
{
|
||||||
@ -122,9 +143,9 @@ appendStringLiteral(PQExpBuffer buf, const char *str, bool escapeAll)
|
|||||||
appendPQExpBufferChar(buf, ch);
|
appendPQExpBufferChar(buf, ch);
|
||||||
}
|
}
|
||||||
else if ((unsigned char) ch < (unsigned char) ' ' &&
|
else if ((unsigned char) ch < (unsigned char) ' ' &&
|
||||||
(escapeAll
|
(escapeAll ||
|
||||||
|| (ch != '\t' && ch != '\n' && ch != '\v' && ch != '\f' && ch != '\r')
|
(ch != '\t' && ch != '\n' && ch != '\v' &&
|
||||||
))
|
ch != '\f' && ch != '\r')))
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* generate octal escape for control chars other than
|
* generate octal escape for control chars other than
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* Implements the basic DB functions used by the archiver.
|
* Implements the basic DB functions used by the archiver.
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.62 2005/06/21 20:45:44 tgl Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_backup_db.c,v 1.63 2005/07/01 21:03:25 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -597,7 +597,6 @@ _sendSQLLine(ArchiveHandle *AH, char *qry, char *eos)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
if (qry[pos] == '\\')
|
if (qry[pos] == '\\')
|
||||||
{
|
{
|
||||||
if (AH->sqlparse.lastChar == '\\')
|
if (AH->sqlparse.lastChar == '\\')
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
* by PostgreSQL
|
* by PostgreSQL
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.411 2005/06/30 03:02:56 tgl Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.412 2005/07/01 21:03:25 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -7767,8 +7767,9 @@ dumpTrigger(Archive *fout, TriggerInfo *tginfo)
|
|||||||
p = tginfo->tgargs;
|
p = tginfo->tgargs;
|
||||||
for (findx = 0; findx < tginfo->tgnargs; findx++)
|
for (findx = 0; findx < tginfo->tgnargs; findx++)
|
||||||
{
|
{
|
||||||
const char *s = p;
|
const char *s = p, *s2 = p;
|
||||||
|
|
||||||
|
/* Set 'p' to end of arg string. marked by '\000' */
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
p = strchr(p, '\\');
|
p = strchr(p, '\\');
|
||||||
@ -7781,20 +7782,29 @@ dumpTrigger(Archive *fout, TriggerInfo *tginfo)
|
|||||||
exit_nicely();
|
exit_nicely();
|
||||||
}
|
}
|
||||||
p++;
|
p++;
|
||||||
if (*p == '\\')
|
if (*p == '\\') /* is it '\\'? */
|
||||||
{
|
{
|
||||||
p++;
|
p++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (p[0] == '0' && p[1] == '0' && p[2] == '0')
|
if (p[0] == '0' && p[1] == '0' && p[2] == '0') /* is it '\000'? */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
p--;
|
p--;
|
||||||
|
|
||||||
|
/* do we need E''? */
|
||||||
|
while (s2 < p)
|
||||||
|
if (*s2++ == '\\')
|
||||||
|
{
|
||||||
|
appendPQExpBufferChar(query, 'E');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
appendPQExpBufferChar(query, '\'');
|
appendPQExpBufferChar(query, '\'');
|
||||||
while (s < p)
|
while (s < p)
|
||||||
{
|
{
|
||||||
if (*s == '\'')
|
if (*s == '\'')
|
||||||
appendPQExpBufferChar(query, '\\');
|
appendPQExpBufferChar(query, '\'');
|
||||||
appendPQExpBufferChar(query, *s++);
|
appendPQExpBufferChar(query, *s++);
|
||||||
}
|
}
|
||||||
appendPQExpBufferChar(query, '\'');
|
appendPQExpBufferChar(query, '\'');
|
||||||
|
Loading…
Reference in New Issue
Block a user