diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2002-04-11 20:00:18 +0000 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2002-04-11 20:00:18 +0000 |
commit | 902a6a0a4bc62d619a5ccd1ef0ff7fb3a5d897f1 (patch) | |
tree | c5cc85818d8a3ffae03a23bacd3e679945a41dbd /src/backend/nodes/readfuncs.c | |
parent | 3f6299df6c7d905bdef44eb3a4b19f248ebc14dc (diff) |
Restructure representation of aggregate functions so that they have pg_proc
entries, per pghackers discussion. This fixes aggregates to live in
namespaces, and also simplifies/speeds up lookup in parse_func.c.
Also, add a 'proimplicit' flag to pg_proc that controls whether a type
coercion function may be invoked implicitly, or only explicitly. The
current settings of these flags are more permissive than I would like,
but we will need to debate and refine the behavior; for now, I avoided
breaking regression tests as much as I could.
Diffstat (limited to 'src/backend/nodes/readfuncs.c')
-rw-r--r-- | src/backend/nodes/readfuncs.c | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/src/backend/nodes/readfuncs.c b/src/backend/nodes/readfuncs.c index 150e98d6e49..f91ba36e5dc 100644 --- a/src/backend/nodes/readfuncs.c +++ b/src/backend/nodes/readfuncs.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/nodes/readfuncs.c,v 1.118 2002/03/22 02:56:32 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/nodes/readfuncs.c,v 1.119 2002/04/11 20:00:00 tgl Exp $ * * NOTES * Most of the read functions for plan nodes are tested. (In fact, they @@ -1159,13 +1159,9 @@ _readAggref(void) local_node = makeNode(Aggref); - token = pg_strtok(&length); /* eat :aggname */ - token = pg_strtok(&length); /* get aggname */ - local_node->aggname = debackslash(token, length); - - token = pg_strtok(&length); /* eat :basetype */ - token = pg_strtok(&length); /* get basetype */ - local_node->basetype = atooid(token); + token = pg_strtok(&length); /* eat :aggfnoid */ + token = pg_strtok(&length); /* get aggfnoid */ + local_node->aggfnoid = atooid(token); token = pg_strtok(&length); /* eat :aggtype */ token = pg_strtok(&length); /* get aggtype */ |