PostgreSQL Source Code git master
btree_date.c
Go to the documentation of this file.
1/*
2 * contrib/btree_gist/btree_date.c
3 */
4#include "postgres.h"
5
6#include "btree_gist.h"
7#include "btree_utils_num.h"
8#include "utils/fmgrprotos.h"
9#include "utils/date.h"
10#include "utils/sortsupport.h"
11
12typedef struct
13{
16} dateKEY;
17
18/* GiST support functions */
28
29static bool
30gbt_dategt(const void *a, const void *b, FmgrInfo *flinfo)
31{
33 DateADTGetDatum(*((const DateADT *) a)),
34 DateADTGetDatum(*((const DateADT *) b))));
35}
36
37static bool
38gbt_datege(const void *a, const void *b, FmgrInfo *flinfo)
39{
41 DateADTGetDatum(*((const DateADT *) a)),
42 DateADTGetDatum(*((const DateADT *) b))));
43}
44
45static bool
46gbt_dateeq(const void *a, const void *b, FmgrInfo *flinfo)
47{
49 DateADTGetDatum(*((const DateADT *) a)),
50 DateADTGetDatum(*((const DateADT *) b)))
51 );
52}
53
54static bool
55gbt_datele(const void *a, const void *b, FmgrInfo *flinfo)
56{
58 DateADTGetDatum(*((const DateADT *) a)),
59 DateADTGetDatum(*((const DateADT *) b))));
60}
61
62static bool
63gbt_datelt(const void *a, const void *b, FmgrInfo *flinfo)
64{
66 DateADTGetDatum(*((const DateADT *) a)),
67 DateADTGetDatum(*((const DateADT *) b))));
68}
69
70
71
72static int
73gbt_datekey_cmp(const void *a, const void *b, FmgrInfo *flinfo)
74{
75 dateKEY *ia = (dateKEY *) (((const Nsrt *) a)->t);
76 dateKEY *ib = (dateKEY *) (((const Nsrt *) b)->t);
77 int res;
78
82 if (res == 0)
86
87 return res;
88}
89
90static float8
91gdb_date_dist(const void *a, const void *b, FmgrInfo *flinfo)
92{
93 /* we assume the difference can't overflow */
95 DateADTGetDatum(*((const DateADT *) a)),
96 DateADTGetDatum(*((const DateADT *) b)));
97
98 return (float8) abs(DatumGetInt32(diff));
99}
100
101
102static const gbtree_ninfo tinfo =
103{
105 sizeof(DateADT),
106 8, /* sizeof(gbtreekey8) */
114};
115
116
118Datum
120{
121 /* we assume the difference can't overflow */
124 PG_GETARG_DATUM(1));
125
126 PG_RETURN_INT32(abs(DatumGetInt32(diff)));
127}
128
129
130/**************************************************
131 * GiST support functions
132 **************************************************/
133
134Datum
136{
137 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
138
140}
141
142Datum
144{
145 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
146
148}
149
150Datum
152{
153 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
154 DateADT query = PG_GETARG_DATEADT(1);
156
157 /* Oid subtype = PG_GETARG_OID(3); */
158 bool *recheck = (bool *) PG_GETARG_POINTER(4);
159 dateKEY *kkk = (dateKEY *) DatumGetPointer(entry->key);
161
162 /* All cases served by this function are exact */
163 *recheck = false;
164
165 key.lower = (GBT_NUMKEY *) &kkk->lower;
166 key.upper = (GBT_NUMKEY *) &kkk->upper;
167
168 PG_RETURN_BOOL(gbt_num_consistent(&key, &query, &strategy,
169 GIST_LEAF(entry), &tinfo,
170 fcinfo->flinfo));
171}
172
173Datum
175{
176 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
177 DateADT query = PG_GETARG_DATEADT(1);
178
179 /* Oid subtype = PG_GETARG_OID(3); */
180 dateKEY *kkk = (dateKEY *) DatumGetPointer(entry->key);
182
183 key.lower = (GBT_NUMKEY *) &kkk->lower;
184 key.upper = (GBT_NUMKEY *) &kkk->upper;
185
187 &tinfo, fcinfo->flinfo));
188}
189
190Datum
192{
194 void *out = palloc(sizeof(dateKEY));
195
196 *(int *) PG_GETARG_POINTER(1) = sizeof(dateKEY);
197 PG_RETURN_POINTER(gbt_num_union(out, entryvec, &tinfo, fcinfo->flinfo));
198}
199
200Datum
202{
203 dateKEY *origentry = (dateKEY *) DatumGetPointer(((GISTENTRY *) PG_GETARG_POINTER(0))->key);
205 float *result = (float *) PG_GETARG_POINTER(2);
206 int32 diff,
207 res;
208
210 DateADTGetDatum(newentry->upper),
211 DateADTGetDatum(origentry->upper)));
212
213 res = Max(diff, 0);
214
216 DateADTGetDatum(origentry->lower),
217 DateADTGetDatum(newentry->lower)));
218
219 res += Max(diff, 0);
220
221 *result = 0.0;
222
223 if (res > 0)
224 {
226 DateADTGetDatum(origentry->upper),
227 DateADTGetDatum(origentry->lower)));
228 *result += FLT_MIN;
229 *result += (float) (res / ((double) (res + diff)));
230 *result *= (FLT_MAX / (((GISTENTRY *) PG_GETARG_POINTER(0))->rel->rd_att->natts + 1));
231 }
232
233 PG_RETURN_POINTER(result);
234}
235
236Datum
238{
241 &tinfo, fcinfo->flinfo));
242}
243
244Datum
246{
247 dateKEY *b1 = (dateKEY *) PG_GETARG_POINTER(0);
248 dateKEY *b2 = (dateKEY *) PG_GETARG_POINTER(1);
249 bool *result = (bool *) PG_GETARG_POINTER(2);
250
251 *result = gbt_num_same((void *) b1, (void *) b2, &tinfo, fcinfo->flinfo);
252 PG_RETURN_POINTER(result);
253}
254
255static int
257{
258 dateKEY *akey = (dateKEY *) DatumGetPointer(x);
259 dateKEY *bkey = (dateKEY *) DatumGetPointer(y);
260
261 /* for leaf items we expect lower == upper, so only compare lower */
263 DateADTGetDatum(akey->lower),
264 DateADTGetDatum(bkey->lower)));
265}
266
267Datum
269{
271
273 ssup->ssup_extra = NULL;
274
276}
static bool gbt_datelt(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:63
Datum gbt_date_fetch(PG_FUNCTION_ARGS)
Definition: btree_date.c:143
Datum gbt_date_consistent(PG_FUNCTION_ARGS)
Definition: btree_date.c:151
Datum gbt_date_penalty(PG_FUNCTION_ARGS)
Definition: btree_date.c:201
static int gbt_date_ssup_cmp(Datum x, Datum y, SortSupport ssup)
Definition: btree_date.c:256
Datum gbt_date_union(PG_FUNCTION_ARGS)
Definition: btree_date.c:191
Datum gbt_date_sortsupport(PG_FUNCTION_ARGS)
Definition: btree_date.c:268
static bool gbt_datege(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:38
PG_FUNCTION_INFO_V1(gbt_date_compress)
static int gbt_datekey_cmp(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:73
static float8 gdb_date_dist(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:91
Datum gbt_date_distance(PG_FUNCTION_ARGS)
Definition: btree_date.c:174
static const gbtree_ninfo tinfo
Definition: btree_date.c:102
static bool gbt_dategt(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:30
Datum gbt_date_same(PG_FUNCTION_ARGS)
Definition: btree_date.c:245
Datum gbt_date_compress(PG_FUNCTION_ARGS)
Definition: btree_date.c:135
static bool gbt_datele(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:55
Datum date_dist(PG_FUNCTION_ARGS)
Definition: btree_date.c:119
static bool gbt_dateeq(const void *a, const void *b, FmgrInfo *flinfo)
Definition: btree_date.c:46
Datum gbt_date_picksplit(PG_FUNCTION_ARGS)
Definition: btree_date.c:237
@ gbt_t_date
Definition: btree_gist.h:27
GISTENTRY * gbt_num_compress(GISTENTRY *entry, const gbtree_ninfo *tinfo)
float8 gbt_num_distance(const GBT_NUMKEY_R *key, const void *query, bool is_leaf, const gbtree_ninfo *tinfo, FmgrInfo *flinfo)
bool gbt_num_consistent(const GBT_NUMKEY_R *key, const void *query, const StrategyNumber *strategy, bool is_leaf, const gbtree_ninfo *tinfo, FmgrInfo *flinfo)
bool gbt_num_same(const GBT_NUMKEY *a, const GBT_NUMKEY *b, const gbtree_ninfo *tinfo, FmgrInfo *flinfo)
GISTENTRY * gbt_num_fetch(GISTENTRY *entry, const gbtree_ninfo *tinfo)
GIST_SPLITVEC * gbt_num_picksplit(const GistEntryVector *entryvec, GIST_SPLITVEC *v, const gbtree_ninfo *tinfo, FmgrInfo *flinfo)
void * gbt_num_union(GBT_NUMKEY *out, const GistEntryVector *entryvec, const gbtree_ninfo *tinfo, FmgrInfo *flinfo)
char GBT_NUMKEY
#define Max(x, y)
Definition: c.h:969
double float8
Definition: c.h:601
int32_t int32
Definition: c.h:498
Datum date_cmp(PG_FUNCTION_ARGS)
Definition: date.c:445
Datum date_le(PG_FUNCTION_ARGS)
Definition: date.c:418
Datum date_eq(PG_FUNCTION_ARGS)
Definition: date.c:391
Datum date_gt(PG_FUNCTION_ARGS)
Definition: date.c:427
Datum date_lt(PG_FUNCTION_ARGS)
Definition: date.c:409
Datum date_ge(PG_FUNCTION_ARGS)
Definition: date.c:436
Datum date_mi(PG_FUNCTION_ARGS)
Definition: date.c:552
static Datum DateADTGetDatum(DateADT X)
Definition: date.h:72
int32 DateADT
Definition: date.h:23
#define PG_GETARG_DATEADT(n)
Definition: date.h:89
#define PG_RETURN_VOID()
Definition: fmgr.h:349
#define DirectFunctionCall2(func, arg1, arg2)
Definition: fmgr.h:684
#define PG_RETURN_FLOAT8(x)
Definition: fmgr.h:367
#define PG_GETARG_POINTER(n)
Definition: fmgr.h:276
#define PG_GETARG_DATUM(n)
Definition: fmgr.h:268
#define PG_GETARG_UINT16(n)
Definition: fmgr.h:272
#define PG_RETURN_INT32(x)
Definition: fmgr.h:354
#define PG_RETURN_POINTER(x)
Definition: fmgr.h:361
#define PG_FUNCTION_ARGS
Definition: fmgr.h:193
#define PG_RETURN_BOOL(x)
Definition: fmgr.h:359
#define GIST_LEAF(entry)
Definition: gist.h:171
int y
Definition: isn.c:76
int b
Definition: isn.c:74
int x
Definition: isn.c:75
int a
Definition: isn.c:73
void * palloc(Size size)
Definition: mcxt.c:1945
static bool DatumGetBool(Datum X)
Definition: postgres.h:95
uintptr_t Datum
Definition: postgres.h:69
static Pointer DatumGetPointer(Datum X)
Definition: postgres.h:317
static int32 DatumGetInt32(Datum X)
Definition: postgres.h:207
struct SortSupportData * SortSupport
Definition: sortsupport.h:58
uint16 StrategyNumber
Definition: stratnum.h:22
Definition: fmgr.h:57
Datum key
Definition: gist.h:161
int(* comparator)(Datum x, Datum y, SortSupport ssup)
Definition: sortsupport.h:106
void * ssup_extra
Definition: sortsupport.h:87
DateADT upper
Definition: btree_date.c:15
DateADT lower
Definition: btree_date.c:14