]> granicus.if.org Git - postgresql/commit
Fix daterange canonicalization for +/- infinity.
authorJeff Davis <jdavis@postgresql.org>
Thu, 18 Jul 2019 21:01:17 +0000 (14:01 -0700)
committerJeff Davis <jdavis@postgresql.org>
Thu, 18 Jul 2019 21:01:17 +0000 (14:01 -0700)
commitf5f20deda33ba4146d68071193289f99c8a5d6c8
tree3e2ba3d6b6ab52cb83e04bbbf4feff50a753e047
parent6523f2ed34413ffcbee8b20d01b0101d9e7dd9c1
Fix daterange canonicalization for +/- infinity.

The values 'infinity' and '-infinity' are a part of the DATE type
itself, so a bound of the date 'infinity' is not the same as an
unbounded/infinite range. However, it is still wrong to try to
canonicalize such values, because adding or subtracting one has no
effect. Fix by treating 'infinity' and '-infinity' the same as
unbounded ranges for the purposes of canonicalization (but not other
purposes).

Backpatch to all versions because it is inconsistent with the
documented behavior. Note that this could be an incompatibility for
applications relying on the behavior contrary to the documentation.

Author: Laurenz Albe
Reviewed-by: Thomas Munro
Discussion: https://postgr.es/m/77f24ea19ab802bc9bc60ddbb8977ee2d646aec1.camel%40cybertec.at
Backpatch-through: 9.4
src/backend/utils/adt/rangetypes.c
src/test/regress/expected/rangetypes.out
src/test/regress/sql/rangetypes.sql