Remove the hack in the grammar that "optimized away" DEFAULT NULL clauses.
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 29 Oct 2007 19:40:40 +0000 (19:40 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 29 Oct 2007 19:40:40 +0000 (19:40 +0000)
commit890bd95d253ea96cf8dbddabe6d895e5d71141c7
tree46ca6d122c48b4aaa72d9d09f297b384a588b18c
parent83c95a70568d95ac8cef18f5d29d115f0abed0f5
Remove the hack in the grammar that "optimized away" DEFAULT NULL clauses.
Instead put in a test to drop a NULL default at the last moment before
storing the catalog entry.  This changes the behavior in a couple of ways:
* Specifying DEFAULT NULL when creating an inheritance child table will
  successfully suppress inheritance of any default expression from the
  parent's column, where formerly it failed to do so.
* Specifying DEFAULT NULL for a column of a domain type will correctly
  override any default belonging to the domain; likewise for a sub-domain.
The latter change happens because by the time the clause is checked,
it won't be a simple null Const but a CoerceToDomain expression.

Personally I think this should be back-patched, but there doesn't seem to
be consensus for that on pgsql-hackers, so refraining.
src/backend/catalog/heap.c
src/backend/commands/typecmds.c
src/backend/parser/gram.y
src/backend/parser/parse_expr.c
src/backend/parser/parse_utilcmd.c
src/include/parser/gramparse.h
src/test/regress/expected/domain.out
src/test/regress/sql/domain.sql