PostgreSQL Source Code git master
Loading...
Searching...
No Matches
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/rel.h"
11#include "utils/sortsupport.h"
12
13typedef struct
14{
17} dateKEY;
18
19/* GiST support functions */
29
30static bool
31gbt_dategt(const void *a, const void *b, FmgrInfo *flinfo)
32{
34 DateADTGetDatum(*((const DateADT *) a)),
35 DateADTGetDatum(*((const DateADT *) b))));
36}
37
38static bool
39gbt_datege(const void *a, const void *b, FmgrInfo *flinfo)
40{
42 DateADTGetDatum(*((const DateADT *) a)),
43 DateADTGetDatum(*((const DateADT *) b))));
44}
45
46static bool
47gbt_dateeq(const void *a, const void *b, FmgrInfo *flinfo)
48{
50 DateADTGetDatum(*((const DateADT *) a)),
51 DateADTGetDatum(*((const DateADT *) b)))
52 );
53}
54
55static bool
56gbt_datele(const void *a, const void *b, FmgrInfo *flinfo)
57{
59 DateADTGetDatum(*((const DateADT *) a)),
60 DateADTGetDatum(*((const DateADT *) b))));
61}
62
63static bool
64gbt_datelt(const void *a, const void *b, FmgrInfo *flinfo)
65{
67 DateADTGetDatum(*((const DateADT *) a)),
68 DateADTGetDatum(*((const DateADT *) b))));
69}
70
71
72
73static int
74gbt_datekey_cmp(const void *a, const void *b, FmgrInfo *flinfo)
75{
76 dateKEY *ia = (dateKEY *) (((const Nsrt *) a)->t);
77 dateKEY *ib = (dateKEY *) (((const Nsrt *) b)->t);
78 int res;
79
81 DateADTGetDatum(ia->lower),
82 DateADTGetDatum(ib->lower)));
83 if (res == 0)
85 DateADTGetDatum(ia->upper),
86 DateADTGetDatum(ib->upper)));
87
88 return res;
89}
90
91static float8
92gdb_date_dist(const void *a, const void *b, FmgrInfo *flinfo)
93{
94 /* we assume the difference can't overflow */
96 DateADTGetDatum(*((const DateADT *) a)),
97 DateADTGetDatum(*((const DateADT *) b)));
98
99 return (float8) abs(DatumGetInt32(diff));
100}
101
102
103static const gbtree_ninfo tinfo =
104{
106 sizeof(DateADT),
107 8, /* sizeof(gbtreekey8) */
115};
116
117
119Datum
121{
122 /* we assume the difference can't overflow */
125 PG_GETARG_DATUM(1));
126
128}
129
130
131/**************************************************
132 * GiST support functions
133 **************************************************/
134
135Datum
142
143Datum
150
151Datum
153{
154 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
155 DateADT query = PG_GETARG_DATEADT(1);
157#ifdef NOT_USED
158 Oid subtype = PG_GETARG_OID(3);
159#endif
160 bool *recheck = (bool *) PG_GETARG_POINTER(4);
161 dateKEY *kkk = (dateKEY *) DatumGetPointer(entry->key);
162 GBT_NUMKEY_R key;
163
164 /* All cases served by this function are exact */
165 *recheck = false;
166
167 key.lower = (GBT_NUMKEY *) &kkk->lower;
168 key.upper = (GBT_NUMKEY *) &kkk->upper;
169
170 PG_RETURN_BOOL(gbt_num_consistent(&key, &query, &strategy,
171 GIST_LEAF(entry), &tinfo,
172 fcinfo->flinfo));
173}
174
175Datum
177{
178 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
179 DateADT query = PG_GETARG_DATEADT(1);
180#ifdef NOT_USED
181 Oid subtype = PG_GETARG_OID(3);
182#endif
183 dateKEY *kkk = (dateKEY *) DatumGetPointer(entry->key);
184 GBT_NUMKEY_R key;
185
186 key.lower = (GBT_NUMKEY *) &kkk->lower;
187 key.upper = (GBT_NUMKEY *) &kkk->upper;
188
189 PG_RETURN_FLOAT8(gbt_num_distance(&key, &query, GIST_LEAF(entry),
190 &tinfo, fcinfo->flinfo));
191}
192
193Datum
195{
197 void *out = palloc(sizeof(dateKEY));
198
199 *(int *) PG_GETARG_POINTER(1) = sizeof(dateKEY);
200 PG_RETURN_POINTER(gbt_num_union(out, entryvec, &tinfo, fcinfo->flinfo));
201}
202
203Datum
205{
208 float *result = (float *) PG_GETARG_POINTER(2);
209 int32 diff,
210 res;
211
214 DateADTGetDatum(origentry->upper)));
215
216 res = Max(diff, 0);
217
220 DateADTGetDatum(newentry->lower)));
221
222 res += Max(diff, 0);
223
224 *result = 0.0;
225
226 if (res > 0)
227 {
230 DateADTGetDatum(origentry->lower)));
231 *result += FLT_MIN;
232 *result += (float) (res / ((double) (res + diff)));
233 *result *= (FLT_MAX / (((GISTENTRY *) PG_GETARG_POINTER(0))->rel->rd_att->natts + 1));
234 }
235
236 PG_RETURN_POINTER(result);
237}
238
239Datum
246
247Datum
249{
252 bool *result = (bool *) PG_GETARG_POINTER(2);
253
254 *result = gbt_num_same((void *) b1, (void *) b2, &tinfo, fcinfo->flinfo);
255 PG_RETURN_POINTER(result);
256}
257
258static int
260{
263
264 /* for leaf items we expect lower == upper, so only compare lower */
266 DateADTGetDatum(akey->lower),
267 DateADTGetDatum(bkey->lower)));
268}
269
270Datum
static bool gbt_datelt(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:64
Datum gbt_date_fetch(PG_FUNCTION_ARGS)
Definition btree_date.c:144
Datum gbt_date_consistent(PG_FUNCTION_ARGS)
Definition btree_date.c:152
Datum gbt_date_penalty(PG_FUNCTION_ARGS)
Definition btree_date.c:204
static int gbt_date_ssup_cmp(Datum x, Datum y, SortSupport ssup)
Definition btree_date.c:259
Datum gbt_date_union(PG_FUNCTION_ARGS)
Definition btree_date.c:194
Datum gbt_date_sortsupport(PG_FUNCTION_ARGS)
Definition btree_date.c:271
static bool gbt_datege(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:39
static int gbt_datekey_cmp(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:74
static float8 gdb_date_dist(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:92
Datum gbt_date_distance(PG_FUNCTION_ARGS)
Definition btree_date.c:176
static const gbtree_ninfo tinfo
Definition btree_date.c:103
static bool gbt_dategt(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:31
Datum gbt_date_same(PG_FUNCTION_ARGS)
Definition btree_date.c:248
Datum gbt_date_compress(PG_FUNCTION_ARGS)
Definition btree_date.c:136
static bool gbt_datele(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:56
Datum date_dist(PG_FUNCTION_ARGS)
Definition btree_date.c:120
static bool gbt_dateeq(const void *a, const void *b, FmgrInfo *flinfo)
Definition btree_date.c:47
Datum gbt_date_picksplit(PG_FUNCTION_ARGS)
Definition btree_date.c:240
@ 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:991
double float8
Definition c.h:644
int32_t int32
Definition c.h:542
Datum date_cmp(PG_FUNCTION_ARGS)
Definition date.c:446
Datum date_le(PG_FUNCTION_ARGS)
Definition date.c:419
Datum date_eq(PG_FUNCTION_ARGS)
Definition date.c:392
Datum date_gt(PG_FUNCTION_ARGS)
Definition date.c:428
Datum date_lt(PG_FUNCTION_ARGS)
Definition date.c:410
Datum date_ge(PG_FUNCTION_ARGS)
Definition date.c:437
Datum date_mi(PG_FUNCTION_ARGS)
Definition date.c:553
static Datum DateADTGetDatum(DateADT X)
Definition date.h:78
int32 DateADT
Definition date.h:21
#define PG_GETARG_DATEADT(n)
Definition date.h:95
#define PG_RETURN_VOID()
Definition fmgr.h:350
#define PG_GETARG_OID(n)
Definition fmgr.h:275
#define DirectFunctionCall2(func, arg1, arg2)
Definition fmgr.h:686
#define PG_RETURN_FLOAT8(x)
Definition fmgr.h:369
#define PG_GETARG_POINTER(n)
Definition fmgr.h:277
#define PG_GETARG_DATUM(n)
Definition fmgr.h:268
#define PG_FUNCTION_INFO_V1(funcname)
Definition fmgr.h:417
#define PG_GETARG_UINT16(n)
Definition fmgr.h:272
#define PG_RETURN_INT32(x)
Definition fmgr.h:355
#define PG_RETURN_POINTER(x)
Definition fmgr.h:363
#define PG_FUNCTION_ARGS
Definition fmgr.h:193
#define PG_RETURN_BOOL(x)
Definition fmgr.h:360
#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:1387
static bool DatumGetBool(Datum X)
Definition postgres.h:100
uint64_t Datum
Definition postgres.h:70
static Pointer DatumGetPointer(Datum X)
Definition postgres.h:342
static int32 DatumGetInt32(Datum X)
Definition postgres.h:212
unsigned int Oid
static int fb(int x)
struct SortSupportData * SortSupport
Definition sortsupport.h:58
uint16 StrategyNumber
Definition stratnum.h:22
Datum key
Definition gist.h:161
int(* comparator)(Datum x, Datum y, SortSupport ssup)
DateADT upper
Definition btree_date.c:16
DateADT lower
Definition btree_date.c:15