aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMagnus Hagander <magnus@hagander.net>2007-05-05 17:05:48 +0000
committerMagnus Hagander <magnus@hagander.net>2007-05-05 17:05:48 +0000
commit343a9a27a9c29c87b4f31ec19947826d12f9102d (patch)
tree9fff248efeb6b188cb8ebc5b8263127546bbf0de
parent4835df303dae1b21c3c334202bea6d698cd38b75 (diff)
downloadpostgresql-343a9a27a9c29c87b4f31ec19947826d12f9102d.tar.gz
postgresql-343a9a27a9c29c87b4f31ec19947826d12f9102d.zip
Check return code from strxfrm on Windows since it has a
non-standard way of indicating errors, so we don't try to allocate INT_MAX bytes to store a result in.
-rw-r--r--src/backend/utils/adt/selfuncs.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/src/backend/utils/adt/selfuncs.c b/src/backend/utils/adt/selfuncs.c
index 079f5e2cc9d..1ba0b4eac48 100644
--- a/src/backend/utils/adt/selfuncs.c
+++ b/src/backend/utils/adt/selfuncs.c
@@ -15,7 +15,7 @@
*
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/backend/utils/adt/selfuncs.c,v 1.233 2007/04/21 21:01:45 tgl Exp $
+ * $PostgreSQL: pgsql/src/backend/utils/adt/selfuncs.c,v 1.234 2007/05/05 17:05:48 mha Exp $
*
*-------------------------------------------------------------------------
*/
@@ -3137,6 +3137,10 @@ convert_string_datum(Datum value, Oid typid)
* from the second call than the first; thus the Assert must be <= not
* == as you'd expect. Can't any of these people program their way
* out of a paper bag?
+ *
+ * XXX: strxfrm doesn't support UTF-8 encoding on Win32, it can return
+ * bogus data or set an error. This is not really a problem unless it
+ * crashes since it will only give an estimation error and nothing fatal.
*/
#if _MSC_VER == 1400 /* VS.Net 2005 */
@@ -3152,6 +3156,15 @@ convert_string_datum(Datum value, Oid typid)
#else
xfrmlen = strxfrm(NULL, val, 0);
#endif
+#ifdef WIN32
+ /*
+ * On Windows, strxfrm returns INT_MAX when an error occurs. Instead of
+ * trying to allocate this much memory (and fail), just return the
+ * original string unmodified as if we were in the C locale.
+ */
+ if (xfrmlen == INT_MAX)
+ return val;
+#endif
xfrmstr = (char *) palloc(xfrmlen + 1);
xfrmlen2 = strxfrm(xfrmstr, val, xfrmlen + 1);
Assert(xfrmlen2 <= xfrmlen);