From ac4878a06009c34bf26b12f358fc45bef13829bf Mon Sep 17 00:00:00 2001
From: Tom Lane <tgl@sss.pgh.pa.us>
Date: Mon, 17 Jan 2000 02:04:16 +0000
Subject: [PATCH] Pass atttypmod to CoerceTargetExpr, so that it can pass it on
 to coerce_type, so that the right things happen when coercing a previously-
 unknown constant to a destination data type.

---
 src/backend/catalog/heap.c           |  6 +++---
 src/backend/parser/parse_clause.c    |  4 ++--
 src/backend/parser/parse_expr.c      |  6 +++---
 src/backend/parser/parse_node.c      | 14 ++++++++------
 src/backend/parser/parse_target.c    | 13 +++++++------
 src/backend/rewrite/rewriteHandler.c |  4 ++--
 src/include/parser/parse_target.h    |  4 ++--
 7 files changed, 27 insertions(+), 24 deletions(-)

diff --git a/src/backend/catalog/heap.c b/src/backend/catalog/heap.c
index 83a4b420bbf..0476f2c8223 100644
--- a/src/backend/catalog/heap.c
+++ b/src/backend/catalog/heap.c
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/catalog/heap.c,v 1.115 2000/01/16 19:57:00 tgl Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/catalog/heap.c,v 1.116 2000/01/17 02:04:12 tgl Exp $
  *
  *
  * INTERFACE ROUTINES
@@ -1966,8 +1966,8 @@ AddRelationRawConstraints(Relation rel,
 
 			if (type_id != atp->atttypid)
 			{
-				if (CoerceTargetExpr(NULL, expr,
-									 type_id, atp->atttypid) == NULL)
+				if (CoerceTargetExpr(NULL, expr, type_id,
+									 atp->atttypid, atp->atttypmod) == NULL)
 					elog(ERROR, "Attribute '%s' is of type '%s'"
 						 " but default expression is of type '%s'"
 						 "\n\tYou will need to rewrite or cast the expression",
diff --git a/src/backend/parser/parse_clause.c b/src/backend/parser/parse_clause.c
index 1f83150def1..0890ef7a630 100644
--- a/src/backend/parser/parse_clause.c
+++ b/src/backend/parser/parse_clause.c
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_clause.c,v 1.48 1999/12/17 14:47:35 thomas Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_clause.c,v 1.49 2000/01/17 02:04:16 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -757,7 +757,7 @@ transformUnionClause(List *unionClause, List *targetlist)
 					Node	   *expr;
 
 					expr = ((TargetEntry *) lfirst(next_target))->expr;
-					expr = CoerceTargetExpr(NULL, expr, itype, otype);
+					expr = CoerceTargetExpr(NULL, expr, itype, otype, -1);
 					if (expr == NULL)
 					{
 						elog(ERROR, "Unable to transform %s to %s"
diff --git a/src/backend/parser/parse_expr.c b/src/backend/parser/parse_expr.c
index 6fe43e9e023..d1e4460b6c0 100644
--- a/src/backend/parser/parse_expr.c
+++ b/src/backend/parser/parse_expr.c
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_expr.c,v 1.65 2000/01/17 00:14:48 tgl Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_expr.c,v 1.66 2000/01/17 02:04:16 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -792,8 +792,8 @@ parser_typecast_expression(ParseState *pstate,
 
 	if (inputType != targetType)
 	{
-		expr = CoerceTargetExpr(pstate, expr,
-								inputType, targetType);
+		expr = CoerceTargetExpr(pstate, expr, inputType,
+								targetType, typename->typmod);
 		if (expr == NULL)
 			elog(ERROR, "Cannot cast type '%s' to '%s'",
 				 typeidTypeName(inputType),
diff --git a/src/backend/parser/parse_node.c b/src/backend/parser/parse_node.c
index 544a4462dd1..0b48beb0491 100644
--- a/src/backend/parser/parse_node.c
+++ b/src/backend/parser/parse_node.c
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.35 2000/01/15 02:59:32 petere Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.36 2000/01/17 02:04:16 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -319,8 +319,8 @@ transformArraySubscripts(ParseState *pstate,
 			{
 				subexpr = transformExpr(pstate, ai->lidx, EXPR_COLUMN_FIRST);
 				/* If it's not int4 already, try to coerce */
-				subexpr = CoerceTargetExpr(pstate, subexpr,
-										   exprType(subexpr), INT4OID);
+				subexpr = CoerceTargetExpr(pstate, subexpr, exprType(subexpr),
+										   INT4OID, -1);
 				if (subexpr == NULL)
 					elog(ERROR, "array index expressions must be integers");
 			}
@@ -339,8 +339,8 @@ transformArraySubscripts(ParseState *pstate,
 		}
 		subexpr = transformExpr(pstate, ai->uidx, EXPR_COLUMN_FIRST);
 		/* If it's not int4 already, try to coerce */
-		subexpr = CoerceTargetExpr(pstate, subexpr,
-								   exprType(subexpr), INT4OID);
+		subexpr = CoerceTargetExpr(pstate, subexpr, exprType(subexpr),
+								   INT4OID, -1);
 		if (subexpr == NULL)
 			elog(ERROR, "array index expressions must be integers");
 		upperIndexpr = lappend(upperIndexpr, subexpr);
@@ -358,8 +358,10 @@ transformArraySubscripts(ParseState *pstate,
 		{
 			if (typesource != typeneeded)
 			{
+				/* XXX fixme: need to get the array's atttypmod? */
 				assignFrom = CoerceTargetExpr(pstate, assignFrom,
-											  typesource, typeneeded);
+											  typesource, typeneeded,
+											  -1);
 				if (assignFrom == NULL)
 					elog(ERROR, "Array assignment requires type '%s'"
 						 " but expression is of type '%s'"
diff --git a/src/backend/parser/parse_target.c b/src/backend/parser/parse_target.c
index f80b6ef4fbb..b6eb7e0b547 100644
--- a/src/backend/parser/parse_target.c
+++ b/src/backend/parser/parse_target.c
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_target.c,v 1.52 2000/01/17 00:14:48 tgl Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/parser/parse_target.c,v 1.53 2000/01/17 02:04:16 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -229,8 +229,8 @@ updateTargetListEntry(ParseState *pstate,
 		{
 			if (type_id != attrtype)
 			{
-				tle->expr = CoerceTargetExpr(pstate, tle->expr,
-											 type_id, attrtype);
+				tle->expr = CoerceTargetExpr(pstate, tle->expr, type_id,
+											 attrtype, attrtypmod);
 				if (tle->expr == NULL)
 					elog(ERROR, "Attribute '%s' is of type '%s'"
 						 " but expression is of type '%s'"
@@ -264,10 +264,11 @@ Node *
 CoerceTargetExpr(ParseState *pstate,
 				 Node *expr,
 				 Oid type_id,
-				 Oid attrtype)
+				 Oid attrtype,
+				 int32 attrtypmod)
 {
 	if (can_coerce_type(1, &type_id, &attrtype))
-		expr = coerce_type(pstate, expr, type_id, attrtype, -1);
+		expr = coerce_type(pstate, expr, type_id, attrtype, attrtypmod);
 
 #ifndef DISABLE_STRING_HACKS
 
@@ -283,7 +284,7 @@ CoerceTargetExpr(ParseState *pstate,
 		{
 		}
 		else if (can_coerce_type(1, &type_id, &text_id))
-			expr = coerce_type(pstate, expr, type_id, text_id, -1);
+			expr = coerce_type(pstate, expr, type_id, text_id, attrtypmod);
 		else
 			expr = NULL;
 	}
diff --git a/src/backend/rewrite/rewriteHandler.c b/src/backend/rewrite/rewriteHandler.c
index 101cd61bed1..dc8f2b832e7 100644
--- a/src/backend/rewrite/rewriteHandler.c
+++ b/src/backend/rewrite/rewriteHandler.c
@@ -6,7 +6,7 @@
  *
  *
  * IDENTIFICATION
- *	  $Header: /cvsroot/pgsql/src/backend/rewrite/rewriteHandler.c,v 1.64 2000/01/05 18:23:48 momjian Exp $
+ *	  $Header: /cvsroot/pgsql/src/backend/rewrite/rewriteHandler.c,v 1.65 2000/01/17 02:04:13 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -1696,7 +1696,7 @@ check_targetlists_are_compatible(List *prev_target, List *current_target)
 			Node	   *expr;
 
 			expr = ((TargetEntry *) lfirst(next_target))->expr;
-			expr = CoerceTargetExpr(NULL, expr, itype, otype);
+			expr = CoerceTargetExpr(NULL, expr, itype, otype, -1);
 			if (expr == NULL)
 			{
 				elog(ERROR, "Unable to transform %s to %s"
diff --git a/src/include/parser/parse_target.h b/src/include/parser/parse_target.h
index 08cf389d72e..022abd58520 100644
--- a/src/include/parser/parse_target.h
+++ b/src/include/parser/parse_target.h
@@ -6,7 +6,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: parse_target.h,v 1.16 1999/11/01 05:06:20 tgl Exp $
+ * $Id: parse_target.h,v 1.17 2000/01/17 02:04:15 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -23,7 +23,7 @@ extern void updateTargetListEntry(ParseState *pstate, TargetEntry *tle,
 								  char *colname, int attrno,
 								  List *indirection);
 extern Node *CoerceTargetExpr(ParseState *pstate, Node *expr,
-							  Oid type_id, Oid attrtype);
+							  Oid type_id, Oid attrtype, int32 attrtypmod);
 extern List *checkInsertTargets(ParseState *pstate, List *cols,
 								List **attrnos);
 
-- 
GitLab