From 7e99cea816bde08ba3bda2de4e972adc624a659e Mon Sep 17 00:00:00 2001 From: Tatsuo Ishii Date: Tue, 11 Sep 2001 05:18:59 +0000 Subject: Implement following item in TODO: * Reject character sequences those are not valid in their charset --- src/backend/utils/adt/varchar.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'src/backend/utils/adt/varchar.c') diff --git a/src/backend/utils/adt/varchar.c b/src/backend/utils/adt/varchar.c index 38b26173ad2..b142d126c1c 100644 --- a/src/backend/utils/adt/varchar.c +++ b/src/backend/utils/adt/varchar.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/varchar.c,v 1.81 2001/07/15 11:07:37 ishii Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/varchar.c,v 1.82 2001/09/11 05:18:59 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -75,10 +75,14 @@ bpcharin(PG_FUNCTION_ARGS) int i; #ifdef MULTIBYTE int charlen; /* number of charcters in the input string */ + char *ermsg; #endif len = strlen(s); #ifdef MULTIBYTE + if ((ermsg = pg_verifymbstr(s, len))) + elog(ERROR,"%s",ermsg); + charlen = pg_mbstrlen(s); #endif @@ -405,8 +409,15 @@ varcharin(PG_FUNCTION_ARGS) int32 atttypmod = PG_GETARG_INT32(2); VarChar *result; size_t len, maxlen; +#ifdef MULTIBYTE + char *ermsg; +#endif len = strlen(s); +#ifdef MULTIBYTE + if ((ermsg = pg_verifymbstr(s, len))) + elog(ERROR,"%s",ermsg); +#endif maxlen = atttypmod - VARHDRSZ; if (atttypmod >= (int32) VARHDRSZ && len > maxlen) -- cgit v1.2.3