expandRTE and get_rte_attribute_type mistakenly always imputed typmod -1
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 29 May 2005 17:10:23 +0000 (17:10 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 29 May 2005 17:10:23 +0000 (17:10 +0000)
to columns of an RTE that was a function returning RECORD with a column
definition list.  Apparently no one has tried to use non-default typmod
with a function returning RECORD before.

src/backend/parser/parse_relation.c

index d1e5fca2aae9453cd7be5f87a786f4510c38dd53..bb32ebdf1c1d20642194d93c13cd87ad9af0fc3e 100644 (file)
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *   $PostgreSQL: pgsql/src/backend/parser/parse_relation.c,v 1.107 2005/04/28 21:47:14 tgl Exp $
+ *   $PostgreSQL: pgsql/src/backend/parser/parse_relation.c,v 1.108 2005/05/29 17:10:23 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -1333,7 +1333,7 @@ expandRTE(List *rtable, int rtindex, int sublevels_up,
                            varnode = makeVar(rtindex,
                                              attnum,
                                              atttypid,
-                                             -1,
+                                             colDef->typename->typmod,
                                              sublevels_up);
 
                            *colvars = lappend(*colvars, varnode);
@@ -1678,7 +1678,7 @@ get_rte_attribute_type(RangeTblEntry *rte, AttrNumber attnum,
                    ColumnDef  *colDef = list_nth(rte->coldeflist, attnum - 1);
 
                    *vartype = typenameTypeId(colDef->typename);
-                   *vartypmod = -1;
+                   *vartypmod = colDef->typename->typmod;
                }
                else
                {