Commit cb05f538 authored by Tom Lane's avatar Tom Lane

There is no good reason for the CREATE TABLE LIKE INCLUDING COMMENTS code to

have hard-wired knowledge of the rules for naming index columns.  It can
just look at the actual names in the source index, instead.  Do some minor
formatting cleanup too.
parent 7d672e1e
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
* Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/backend/parser/parse_utilcmd.c,v 2.32 2009/12/15 17:57:47 tgl Exp $ * $PostgreSQL: pgsql/src/backend/parser/parse_utilcmd.c,v 2.33 2009/12/20 18:28:14 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -745,21 +745,26 @@ transformInhRelation(ParseState *pstate, CreateStmtContext *cxt, ...@@ -745,21 +745,26 @@ transformInhRelation(ParseState *pstate, CreateStmtContext *cxt,
/* Copy comment on index */ /* Copy comment on index */
if (inhRelation->options & CREATE_TABLE_LIKE_COMMENTS) if (inhRelation->options & CREATE_TABLE_LIKE_COMMENTS)
{ {
Form_pg_attribute *attrs;
CommentStmt *stmt; CommentStmt *stmt;
ListCell *lc; int colno;
int i;
comment = GetComment(parent_index_oid, RelationRelationId, 0); comment = GetComment(parent_index_oid, RelationRelationId, 0);
if (comment != NULL) if (comment != NULL)
{ {
/* Assign name for index because CommentStmt requires name. */ /*
* We have to assign the index a name now, so that we
* can reference it in CommentStmt.
*/
if (index_stmt->idxname == NULL) if (index_stmt->idxname == NULL)
index_stmt->idxname = chooseIndexName(cxt->relation, index_stmt); index_stmt->idxname = chooseIndexName(cxt->relation,
index_stmt);
stmt = makeNode(CommentStmt); stmt = makeNode(CommentStmt);
stmt->objtype = OBJECT_INDEX; stmt->objtype = OBJECT_INDEX;
stmt->objname = list_make2(makeString(cxt->relation->schemaname), stmt->objname =
list_make2(makeString(cxt->relation->schemaname),
makeString(index_stmt->idxname)); makeString(index_stmt->idxname));
stmt->objargs = NIL; stmt->objargs = NIL;
stmt->comment = comment; stmt->comment = comment;
...@@ -767,34 +772,33 @@ transformInhRelation(ParseState *pstate, CreateStmtContext *cxt, ...@@ -767,34 +772,33 @@ transformInhRelation(ParseState *pstate, CreateStmtContext *cxt,
cxt->alist = lappend(cxt->alist, stmt); cxt->alist = lappend(cxt->alist, stmt);
} }
/* Copy comment on index's columns */ /* Copy comments on index's columns */
i = 0; attrs = RelationGetDescr(parent_index)->attrs;
foreach(lc, index_stmt->indexParams) for (colno = 1;
colno <= RelationGetNumberOfAttributes(parent_index);
colno++)
{ {
char *attname; char *attname;
i++; comment = GetComment(parent_index_oid, RelationRelationId,
comment = GetComment(parent_index_oid, RelationRelationId, i); colno);
if (comment == NULL) if (comment == NULL)
continue; continue;
/* Assign name for index because CommentStmt requires name. */ /*
* We have to assign the index a name now, so that we
* can reference it in CommentStmt.
*/
if (index_stmt->idxname == NULL) if (index_stmt->idxname == NULL)
index_stmt->idxname = chooseIndexName(cxt->relation, index_stmt); index_stmt->idxname = chooseIndexName(cxt->relation,
index_stmt);
attname = ((IndexElem *) lfirst(lc))->name;
/* expression index has a dummy column name */ attname = NameStr(attrs[colno - 1]->attname);
if (attname == NULL)
{
attname = palloc(NAMEDATALEN);
sprintf(attname, "pg_expression_%d", i);
}
stmt = makeNode(CommentStmt); stmt = makeNode(CommentStmt);
stmt->objtype = OBJECT_COLUMN; stmt->objtype = OBJECT_COLUMN;
stmt->objname = list_make3( stmt->objname =
makeString(cxt->relation->schemaname), list_make3(makeString(cxt->relation->schemaname),
makeString(index_stmt->idxname), makeString(index_stmt->idxname),
makeString(attname)); makeString(attname));
stmt->objargs = NIL; stmt->objargs = NIL;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment