]> granicus.if.org Git - postgresql/commit
Major patch from Thomas Lockhart <Thomas.G.Lockhart@jpl.nasa.gov>
authorMarc G. Fournier <scrappy@hub.org>
Tue, 22 Apr 1997 17:35:09 +0000 (17:35 +0000)
committerMarc G. Fournier <scrappy@hub.org>
Tue, 22 Apr 1997 17:35:09 +0000 (17:35 +0000)
commit9e2a87b62db87fc4175b00dabfd26293a2d072fa
tree431dc2f390475e033dc2cfda38fddb6a79e4abb2
parent051b4210e3cb3f3a9ec7cd5ab4503b48f279ab48
Major patch from Thomas Lockhart <Thomas.G.Lockhart@jpl.nasa.gov>

OK, here are a passel of patches for the geometric data types.
These add a "circle" data type, new operators and functions
for the existing data types, and change the default formats
for some of the existing types to make them consistant with
each other. Current formatting conventions (e.g. compatible
with v6.0 to allow dump/reload) are supported, but the new
conventions should be an improvement and we can eventually
drop the old conventions entirely.

For example, there are two kinds of paths (connected line segments),
open and closed, and the old format was

'(1,2,1,2,3,4)' for a closed path with two points (1,2) and (3,4)
'(0,2,1,2,3,4)' for an open path with two points (1,2) and (3,4)

Pretty arcane, huh? The new format for paths is

'((1,2),(3,4))' for a closed path with two points (1,2) and (3,4)
'[(1,2),(3,4)]' for an open path with two points (1,2) and (3,4)

For polygons, the old convention is

'(0,4,2,0,4,3)' for a triangle with points at (0,0),(4,4), and (2,3)

and the new convention is

'((0,0),(4,4),(2,3))' for a triangle with points at (0,0),(4,4), and (2,3)

Other data types which are also represented as lists of points
(e.g. boxes, line segments, and polygons) have similar representations
(they surround each point with parens).

For v6.1, any format which can be interpreted as the old style format
is decoded as such; we can remove that backwards compatibility but ugly
convention for v7.0. This will allow dump/reloads from v6.0.

These include some updates to the regression test files to change the test
for creating a data type from "circle" to "widget" to keep the test from
trashing the new builtin circle type.
13 files changed:
src/backend/access/rtree/rtproc.c
src/backend/utils/adt/geo_ops.c
src/include/catalog/pg_operator.h
src/include/catalog/pg_proc.h
src/include/catalog/pg_type.h
src/include/utils/geo_decls.h
src/test/regress/expected/create_operator.out
src/test/regress/expected/create_type.out
src/test/regress/expected/misc.out
src/test/regress/input/create_function.source
src/test/regress/regress.c
src/test/regress/sql/create_operator.sql
src/test/regress/sql/create_type.sql