diff options
Diffstat (limited to 'src/backend/nodes/copyfuncs.c')
-rw-r--r-- | src/backend/nodes/copyfuncs.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/backend/nodes/copyfuncs.c b/src/backend/nodes/copyfuncs.c index 5d848df5ab4..1e2373c25f1 100644 --- a/src/backend/nodes/copyfuncs.c +++ b/src/backend/nodes/copyfuncs.c @@ -7,7 +7,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/nodes/copyfuncs.c,v 1.16 1997/11/25 21:59:40 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/nodes/copyfuncs.c,v 1.17 1997/12/18 03:03:31 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -516,7 +516,7 @@ _copyAgg(Agg *from) CopyTempFields((Temp *) from, (Temp *) newnode); newnode->numAgg = from->numAgg; - newnode->aggs = malloc(sizeof(Aggreg *)); + newnode->aggs = palloc(sizeof(Aggreg *)); for (i = 0; i < from->numAgg; i++) { newnode->aggs[i] = copyObject(from->aggs[i]); @@ -1519,7 +1519,7 @@ static Query * _copyQuery(Query *from) { Query *newnode = makeNode(Query); - + newnode->commandType = from->commandType; newnode->resultRelation = from->resultRelation; /* probably should dup this string instead of just pointing */ @@ -1555,6 +1555,11 @@ _copyQuery(Query *from) Node_Copy(from, newnode, targetList); Node_Copy(from, newnode, qual); + Node_Copy(from, newnode, groupClause); + Node_Copy(from, newnode, havingQual); /* currently ignored */ + + Node_Copy(from, newnode, Aggreg); + return newnode; } |