PostgreSQL Source Code git master
btree_bit.c
Go to the documentation of this file.
1/*
2 * contrib/btree_gist/btree_bit.c
3 */
4#include "postgres.h"
5
6#include "btree_gist.h"
7#include "btree_utils_var.h"
8#include "utils/fmgrprotos.h"
9#include "utils/sortsupport.h"
10#include "utils/varbit.h"
11#include "varatt.h"
12
13/* GiST support functions */
22
23
24/* define for comparison */
25
26static bool
27gbt_bitgt(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
28{
32}
33
34static bool
35gbt_bitge(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
36{
40}
41
42static bool
43gbt_biteq(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
44{
48}
49
50static bool
51gbt_bitle(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
52{
56}
57
58static bool
59gbt_bitlt(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
60{
64}
65
66static int32
67gbt_bitcmp(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
68{
72}
73
74
75static bytea *
77{
78 bytea *out = leaf;
79 int sz = VARBITBYTES(leaf) + VARHDRSZ;
80 int padded_sz = INTALIGN(sz);
81
82 out = (bytea *) palloc(padded_sz);
83 /* initialize the padding bytes to zero */
84 while (sz < padded_sz)
85 ((char *) out)[sz++] = 0;
86 SET_VARSIZE(out, padded_sz);
87 memcpy(VARDATA(out), VARBITS(leaf), VARBITBYTES(leaf));
88 return out;
89}
90
91
92
93
94static GBT_VARKEY *
96{
97 GBT_VARKEY *out = leaf;
99 bytea *o;
100
101 o = gbt_bit_xfrm(r.lower);
102 r.upper = r.lower = o;
103 out = gbt_var_key_copy(&r);
104 pfree(o);
105
106 return out;
107}
108
109static const gbtree_vinfo tinfo =
110{
111 gbt_t_bit,
112 0,
113 true,
114 gbt_bitgt,
115 gbt_bitge,
116 gbt_biteq,
117 gbt_bitle,
118 gbt_bitlt,
121};
122
123
124/**************************************************
125 * GiST support functions
126 **************************************************/
127
128Datum
130{
131 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
132
134}
135
136Datum
138{
139 GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
140 void *query = DatumGetByteaP(PG_GETARG_DATUM(1));
142
143 /* Oid subtype = PG_GETARG_OID(3); */
144 bool *recheck = (bool *) PG_GETARG_POINTER(4);
145 bool retval;
148
149 /* All cases served by this function are exact */
150 *recheck = false;
151
152 if (GIST_LEAF(entry))
153 retval = gbt_var_consistent(&r, query, strategy, PG_GET_COLLATION(),
154 true, &tinfo, fcinfo->flinfo);
155 else
156 {
157 bytea *q = gbt_bit_xfrm((bytea *) query);
158
159 retval = gbt_var_consistent(&r, q, strategy, PG_GET_COLLATION(),
160 false, &tinfo, fcinfo->flinfo);
161 }
162 PG_RETURN_BOOL(retval);
163}
164
165Datum
167{
169 int32 *size = (int *) PG_GETARG_POINTER(1);
170
172 &tinfo, fcinfo->flinfo));
173}
174
175Datum
177{
180
181 gbt_var_picksplit(entryvec, v, PG_GET_COLLATION(),
182 &tinfo, fcinfo->flinfo);
184}
185
186Datum
188{
189 Datum d1 = PG_GETARG_DATUM(0);
190 Datum d2 = PG_GETARG_DATUM(1);
191 bool *result = (bool *) PG_GETARG_POINTER(2);
192
193 *result = gbt_var_same(d1, d2, PG_GET_COLLATION(), &tinfo, fcinfo->flinfo);
194 PG_RETURN_POINTER(result);
195}
196
197Datum
199{
202 float *result = (float *) PG_GETARG_POINTER(2);
203
205 &tinfo, fcinfo->flinfo));
206}
207
208static int
210{
213
216 Datum result;
217
218 /* for leaf items we expect lower == upper, so only compare lower */
221 PointerGetDatum(arg2.lower));
222
223 GBT_FREE_IF_COPY(key1, x);
224 GBT_FREE_IF_COPY(key2, y);
225
226 return DatumGetInt32(result);
227}
228
229Datum
231{
233
235 ssup->ssup_extra = NULL;
236
238}
239
240Datum
242{
244
246 ssup->ssup_extra = NULL;
247
249}
static bool gbt_bitge(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:35
Datum gbt_bit_same(PG_FUNCTION_ARGS)
Definition: btree_bit.c:187
static bool gbt_bitgt(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:27
static int32 gbt_bitcmp(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:67
PG_FUNCTION_INFO_V1(gbt_bit_compress)
Datum gbt_bit_sortsupport(PG_FUNCTION_ARGS)
Definition: btree_bit.c:230
Datum gbt_varbit_sortsupport(PG_FUNCTION_ARGS)
Definition: btree_bit.c:241
static bool gbt_bitle(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:51
static const gbtree_vinfo tinfo
Definition: btree_bit.c:109
Datum gbt_bit_consistent(PG_FUNCTION_ARGS)
Definition: btree_bit.c:137
Datum gbt_bit_penalty(PG_FUNCTION_ARGS)
Definition: btree_bit.c:198
Datum gbt_bit_compress(PG_FUNCTION_ARGS)
Definition: btree_bit.c:129
static bool gbt_biteq(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:43
static bool gbt_bitlt(const void *a, const void *b, Oid collation, FmgrInfo *flinfo)
Definition: btree_bit.c:59
static GBT_VARKEY * gbt_bit_l2n(GBT_VARKEY *leaf, FmgrInfo *flinfo)
Definition: btree_bit.c:95
static int gbt_bit_ssup_cmp(Datum x, Datum y, SortSupport ssup)
Definition: btree_bit.c:209
Datum gbt_bit_union(PG_FUNCTION_ARGS)
Definition: btree_bit.c:166
static bytea * gbt_bit_xfrm(bytea *leaf)
Definition: btree_bit.c:76
Datum gbt_bit_picksplit(PG_FUNCTION_ARGS)
Definition: btree_bit.c:176
@ gbt_t_bit
Definition: btree_gist.h:34
GBT_VARKEY * gbt_var_union(const GistEntryVector *entryvec, int32 *size, Oid collation, const gbtree_vinfo *tinfo, FmgrInfo *flinfo)
bool gbt_var_consistent(GBT_VARKEY_R *key, const void *query, StrategyNumber strategy, Oid collation, bool is_leaf, const gbtree_vinfo *tinfo, FmgrInfo *flinfo)
GISTENTRY * gbt_var_compress(GISTENTRY *entry, const gbtree_vinfo *tinfo)
GIST_SPLITVEC * gbt_var_picksplit(const GistEntryVector *entryvec, GIST_SPLITVEC *v, Oid collation, const gbtree_vinfo *tinfo, FmgrInfo *flinfo)
GBT_VARKEY_R gbt_var_key_readable(const GBT_VARKEY *k)
float * gbt_var_penalty(float *res, const GISTENTRY *o, const GISTENTRY *n, Oid collation, const gbtree_vinfo *tinfo, FmgrInfo *flinfo)
GBT_VARKEY * gbt_var_key_copy(const GBT_VARKEY_R *u)
bool gbt_var_same(Datum d1, Datum d2, Oid collation, const gbtree_vinfo *tinfo, FmgrInfo *flinfo)
#define GBT_FREE_IF_COPY(ptr1, ptr2)
Datum byteacmp(PG_FUNCTION_ARGS)
Definition: bytea.c:945
#define INTALIGN(LEN)
Definition: c.h:812
#define VARHDRSZ
Definition: c.h:702
int32_t int32
Definition: c.h:539
#define PG_RETURN_VOID()
Definition: fmgr.h:349
#define DirectFunctionCall2(func, arg1, arg2)
Definition: fmgr.h:684
#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_DETOAST_DATUM(datum)
Definition: fmgr.h:240
#define PG_RETURN_POINTER(x)
Definition: fmgr.h:361
#define PG_GET_COLLATION()
Definition: fmgr.h:198
#define PG_FUNCTION_ARGS
Definition: fmgr.h:193
#define PG_RETURN_BOOL(x)
Definition: fmgr.h:359
#define DatumGetByteaP(X)
Definition: fmgr.h:331
#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 pfree(void *pointer)
Definition: mcxt.c:1594
void * palloc(Size size)
Definition: mcxt.c:1365
static bool DatumGetBool(Datum X)
Definition: postgres.h:100
static Datum PointerGetDatum(const void *X)
Definition: postgres.h:332
uint64_t Datum
Definition: postgres.h:70
static Pointer DatumGetPointer(Datum X)
Definition: postgres.h:322
static int32 DatumGetInt32(Datum X)
Definition: postgres.h:212
unsigned int Oid
Definition: postgres_ext.h:32
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
Definition: c.h:697
static char * VARDATA(const void *PTR)
Definition: varatt.h:305
static void SET_VARSIZE(void *PTR, Size len)
Definition: varatt.h:432
Datum bitge(PG_FUNCTION_ARGS)
Definition: varbit.c:934
Datum bitle(PG_FUNCTION_ARGS)
Definition: varbit.c:904
Datum biteq(PG_FUNCTION_ARGS)
Definition: varbit.c:841
Datum bitlt(PG_FUNCTION_ARGS)
Definition: varbit.c:889
Datum bitgt(PG_FUNCTION_ARGS)
Definition: varbit.c:919
#define VARBITBYTES(PTR)
Definition: varbit.h:73
#define VARBITS(PTR)
Definition: varbit.h:71