aboutsummaryrefslogtreecommitdiff
path: root/src/backend/tcop/postgres.c
diff options
context:
space:
mode:
authorAlvaro Herrera <alvherre@alvh.no-ip.org>2019-12-10 17:09:32 -0300
committerAlvaro Herrera <alvherre@alvh.no-ip.org>2019-12-10 17:12:56 -0300
commit6cafde1bd43f1c28b044953cac2f2999eb425b22 (patch)
treef08bc9618832f34f0a26192ab04014d7300e43d8 /src/backend/tcop/postgres.c
parent0da33c762b85aeada111aa1371c33ac6737f8396 (diff)
downloadpostgresql-6cafde1bd43f1c28b044953cac2f2999eb425b22.tar.gz
postgresql-6cafde1bd43f1c28b044953cac2f2999eb425b22.zip
Add backend-only appendStringInfoStringQuoted
This provides a mechanism to emit literal values in informative messages, such as query parameters. The new code is more complex than what it replaces, primarily because it wants to be more efficient. It also has the (currently unused) additional optional capability of specifying a maximum size to print. The new function lives out of common/stringinfo.c so that frontend users of that file need not pull in unnecessary multibyte-encoding support code. Author: Álvaro Herrera and Alexey Bashtanov, after a suggestion from Andres Freund Reviewed-by: Tom Lane Discussion: https://postgr.es/m/20190920203905.xkv5udsd5dxfs6tr@alap3.anarazel.de
Diffstat (limited to 'src/backend/tcop/postgres.c')
-rw-r--r--src/backend/tcop/postgres.c11
1 files changed, 2 insertions, 9 deletions
diff --git a/src/backend/tcop/postgres.c b/src/backend/tcop/postgres.c
index 3b85e48333d..512209a38c4 100644
--- a/src/backend/tcop/postgres.c
+++ b/src/backend/tcop/postgres.c
@@ -48,6 +48,7 @@
#include "libpq/pqformat.h"
#include "libpq/pqsignal.h"
#include "mb/pg_wchar.h"
+#include "mb/stringinfo_mb.h"
#include "miscadmin.h"
#include "nodes/print.h"
#include "optimizer/optimizer.h"
@@ -2348,7 +2349,6 @@ errdetail_params(ParamListInfo params)
Oid typoutput;
bool typisvarlena;
char *pstring;
- char *p;
appendStringInfo(&param_str, "%s$%d = ",
paramno > 0 ? ", " : "",
@@ -2364,14 +2364,7 @@ errdetail_params(ParamListInfo params)
pstring = OidOutputFunctionCall(typoutput, prm->value);
- appendStringInfoCharMacro(&param_str, '\'');
- for (p = pstring; *p; p++)
- {
- if (*p == '\'') /* double single quotes */
- appendStringInfoCharMacro(&param_str, *p);
- appendStringInfoCharMacro(&param_str, *p);
- }
- appendStringInfoCharMacro(&param_str, '\'');
+ appendStringInfoStringQuoted(&param_str, pstring, 0);
pfree(pstring);
}