]> granicus.if.org Git - postgresql/commit
Further planner/optimizer cleanups. Move all set_tlist_references
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 22 Aug 1999 20:15:04 +0000 (20:15 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 22 Aug 1999 20:15:04 +0000 (20:15 +0000)
commit78114cd4d4fd99feb0c753de34d358b16d1ff0ee
tree58838858badf427beddaafe425a9def510741d37
parentdb436adf761bd5cb7990745ceba2959ac4bfca7c
Further planner/optimizer cleanups.  Move all set_tlist_references
and fix_opids processing to a single recursive pass over the plan tree
executed at the very tail end of planning, rather than haphazardly here
and there at different places.  Now that tlist Vars do not get modified
until the very end, it's possible to get rid of the klugy var_equal and
match_varid partial-matching routines, and just use plain equal()
throughout the optimizer.  This is a step towards allowing merge and
hash joins to be done on expressions instead of only Vars ...
24 files changed:
doc/src/sgml/arch-dev.sgml
src/backend/commands/indexcmds.c
src/backend/executor/nodeAgg.c
src/backend/nodes/makefuncs.c
src/backend/optimizer/path/costsize.c
src/backend/optimizer/path/pathkeys.c
src/backend/optimizer/plan/createplan.c
src/backend/optimizer/plan/initsplan.c
src/backend/optimizer/plan/planmain.c
src/backend/optimizer/plan/planner.c
src/backend/optimizer/plan/setrefs.c
src/backend/optimizer/plan/subselect.c
src/backend/optimizer/prep/preptlist.c
src/backend/optimizer/util/clauses.c
src/backend/optimizer/util/tlist.c
src/backend/optimizer/util/var.c
src/backend/parser/parse_func.c
src/backend/parser/parse_node.c
src/include/nodes/makefuncs.h
src/include/nodes/primnodes.h
src/include/optimizer/clauses.h
src/include/optimizer/planmain.h
src/include/optimizer/tlist.h
src/include/optimizer/var.h