aboutsummaryrefslogtreecommitdiff
path: root/contrib/rtree_gist/rtree_gist.sql.in
blob: b32671227fa8c07ca211c0b70c8c5a462a72d9df (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
begin transaction;

-- Adjust this setting to control where the objects get created.
SET search_path = public;

--
--
--
-- BOX ops
--
--
--
-- define the GiST support methods
create function gbox_consistent(internal,box,int4) returns bool as 'MODULE_PATHNAME' language 'C';

create function gbox_compress(internal) returns internal as 'MODULE_PATHNAME' language 'C';

create function rtree_decompress(internal) returns internal as 'MODULE_PATHNAME' language 'C';

create function gbox_penalty(internal,internal,internal) returns internal as 'MODULE_PATHNAME' language 'C' with (isstrict);

create function gbox_picksplit(internal, internal) returns internal as 'MODULE_PATHNAME' language 'C';

create function gbox_union(bytea, internal) returns box as 'MODULE_PATHNAME' language 'C';

create function gbox_same(box, box, internal) returns internal as 'MODULE_PATHNAME' language 'C';

-- create the operator class
CREATE OPERATOR CLASS gist_box_ops
    DEFAULT FOR TYPE box USING gist AS
	OPERATOR	1	<< ,
	OPERATOR	2	&< ,
	OPERATOR	3	&& ,
	OPERATOR	4	&> ,
	OPERATOR	5	>> ,
	OPERATOR	6	~= ,
	OPERATOR	7	~ ,
	OPERATOR	8	@ ,
	FUNCTION	1	gbox_consistent (internal, box, int4),
	FUNCTION	2	gbox_union (bytea, internal),
	FUNCTION	3	gbox_compress (internal),
	FUNCTION	4	rtree_decompress (internal),
	FUNCTION	5	gbox_penalty (internal, internal, internal),
	FUNCTION	6	gbox_picksplit (internal, internal),
	FUNCTION	7	gbox_same (box, box, internal);


--
--
--
-- POLYGON ops
--
--
--
-- define the GiST support methods
create function gpoly_consistent(internal,polygon,int4) returns bool as 'MODULE_PATHNAME' language 'C';

create function gpoly_compress(internal) returns internal as 'MODULE_PATHNAME' language 'C';

-- create the operator class
CREATE OPERATOR CLASS gist_poly_ops
    DEFAULT FOR TYPE polygon USING gist AS
	OPERATOR	1	<<	RECHECK ,
	OPERATOR	2	&<	RECHECK ,
	OPERATOR	3	&&	RECHECK ,
	OPERATOR	4	&>	RECHECK ,
	OPERATOR	5	>>	RECHECK ,
	OPERATOR	6	~=	RECHECK ,
	OPERATOR	7	~	RECHECK ,
	OPERATOR	8	@	RECHECK ,
	FUNCTION	1	gpoly_consistent (internal, polygon, int4),
	FUNCTION	2	gbox_union (bytea, internal),
	FUNCTION	3	gpoly_compress (internal),
	FUNCTION	4	rtree_decompress (internal),
	FUNCTION	5	gbox_penalty (internal, internal, internal),
	FUNCTION	6	gbox_picksplit (internal, internal),
	FUNCTION	7	gbox_same (box, box, internal),
	STORAGE		box;


end transaction;