summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2009-08-16 18:14:34 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2009-08-16 18:14:34 +0000
commit785cfee0313fb04713d11b23413abf9a61c89a6f (patch)
tree3e34313e84fd8e73a74ea80f536a17fce78d9a97
parenta05a4b478d28b5a8b423b0374c3bf65d84c90a7d (diff)
downloadpostgresql-785cfee0313fb04713d11b23413abf9a61c89a6f.tar.gz
Fix incorrect encoding-aware name truncation in makeArrayTypeName().
truncate_identifier won't do anything if the passed-in strlen is already less than NAMEDATALEN, which it always would be given the strlcpy usage. This has been broken since the arrays-of-composite-types code went in. Arguably truncate_identifier is suffering from excessive optimization and should always process the string, but for the moment I'll take the more localized patch. Per bug #4987.
-rw-r--r--src/backend/catalog/pg_type.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/backend/catalog/pg_type.c b/src/backend/catalog/pg_type.c
index 4c7e3f5078..8bdea06153 100644
--- a/src/backend/catalog/pg_type.c
+++ b/src/backend/catalog/pg_type.c
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
- * $PostgreSQL: pgsql/src/backend/catalog/pg_type.c,v 1.126 2009/06/11 14:48:55 momjian Exp $
+ * $PostgreSQL: pgsql/src/backend/catalog/pg_type.c,v 1.127 2009/08/16 18:14:34 tgl Exp $
*
*-------------------------------------------------------------------------
*/
@@ -686,23 +686,27 @@ RenameTypeInternal(Oid typeOid, const char *newTypeName, Oid typeNamespace)
char *
makeArrayTypeName(const char *typeName, Oid typeNamespace)
{
- char *arr;
- int i;
+ char *arr = (char *) palloc(NAMEDATALEN);
+ int namelen = strlen(typeName);
Relation pg_type_desc;
+ int i;
/*
* The idea is to prepend underscores as needed until we make a name that
* doesn't collide with anything...
*/
- arr = palloc(NAMEDATALEN);
-
pg_type_desc = heap_open(TypeRelationId, AccessShareLock);
for (i = 1; i < NAMEDATALEN - 1; i++)
{
arr[i - 1] = '_';
- strlcpy(arr + i, typeName, NAMEDATALEN - i);
- truncate_identifier(arr, strlen(arr), false);
+ if (i + namelen < NAMEDATALEN)
+ strcpy(arr + i, typeName);
+ else
+ {
+ memcpy(arr + i, typeName, NAMEDATALEN - i);
+ truncate_identifier(arr, NAMEDATALEN, false);
+ }
if (!SearchSysCacheExists(TYPENAMENSP,
CStringGetDatum(arr),
ObjectIdGetDatum(typeNamespace),