]> granicus.if.org Git - postgresql/commitdiff
pgstat's truncation of query string needs to be multibyte-aware.
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 7 Feb 2002 22:20:26 +0000 (22:20 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 7 Feb 2002 22:20:26 +0000 (22:20 +0000)
Patch from sugita@sra.co.jp.

src/backend/postmaster/pgstat.c

index fc2619ee0c741640886af77e87c83e88e0865a78..0e9f57500de27f233737dbe370e94204dfbea628 100644 (file)
@@ -16,7 +16,7 @@
  *
  *     Copyright (c) 2001, PostgreSQL Global Development Group
  *
- *     $Header: /cvsroot/pgsql/src/backend/postmaster/pgstat.c,v 1.16 2001/12/03 19:02:58 tgl Exp $
+ *     $Header: /cvsroot/pgsql/src/backend/postmaster/pgstat.c,v 1.17 2002/02/07 22:20:26 tgl Exp $
  * ----------
  */
 #include "postgres.h"
@@ -38,6 +38,9 @@
 #include "catalog/pg_shadow.h"
 #include "catalog/pg_database.h"
 #include "libpq/pqsignal.h"
+#ifdef MULTIBYTE
+#include "mb/pg_wchar.h"
+#endif
 #include "miscadmin.h"
 #include "utils/memutils.h"
 #include "storage/backendid.h"
@@ -424,8 +427,12 @@ pgstat_report_activity(char *what)
                return;
 
        len = strlen(what);
+#ifdef MULTIBYTE
+       len = pg_mbcliplen((const unsigned char *)what, len, PGSTAT_ACTIVITY_SIZE - 1);
+#else
        if (len >= PGSTAT_ACTIVITY_SIZE)
                len = PGSTAT_ACTIVITY_SIZE - 1;
+#endif
 
        memcpy(msg.m_what, what, len);
        msg.m_what[len] = '\0';