mirror of
https://github.com/postgres/postgres.git
synced 2025-07-23 03:21:12 +03:00
config
contrib
adminpack
amcheck
auth_delay
auto_explain
bloom
btree_gin
btree_gist
data
expected
sql
.gitignore
Makefile
btree_bit.c
btree_bytea.c
btree_cash.c
btree_date.c
btree_enum.c
btree_float4.c
btree_float8.c
btree_gist--1.0--1.1.sql
btree_gist--1.1--1.2.sql
btree_gist--1.2--1.3.sql
btree_gist--1.2.sql
btree_gist--1.3--1.4.sql
btree_gist--1.4--1.5.sql
btree_gist--unpackaged--1.0.sql
btree_gist.c
btree_gist.control
btree_gist.h
btree_inet.c
btree_int2.c
btree_int4.c
btree_int8.c
btree_interval.c
btree_macaddr.c
btree_macaddr8.c
btree_numeric.c
btree_oid.c
btree_text.c
btree_time.c
btree_ts.c
btree_utils_num.c
btree_utils_num.h
btree_utils_var.c
btree_utils_var.h
btree_uuid.c
citext
cube
dblink
dict_int
dict_xsyn
earthdistance
file_fdw
fuzzystrmatch
hstore
hstore_plperl
hstore_plpython
intagg
intarray
isn
jsonb_plperl
jsonb_plpython
lo
ltree
ltree_plpython
oid2name
pageinspect
passwordcheck
pg_buffercache
pg_freespacemap
pg_prewarm
pg_standby
pg_stat_statements
pg_trgm
pg_visibility
pgcrypto
pgrowlocks
pgstattuple
postgres_fdw
seg
sepgsql
spi
sslinfo
start-scripts
tablefunc
tcn
test_decoding
tsm_system_rows
tsm_system_time
unaccent
uuid-ossp
vacuumlo
xml2
Makefile
README
contrib-global.mk
doc
src
.dir-locals.el
.gitattributes
.gitignore
COPYRIGHT
GNUmakefile.in
HISTORY
Makefile
README
README.git
aclocal.m4
configure
configure.in
Don't move parenthesized lines to the left, even if that means they flow past the right margin. By default, BSD indent lines up statement continuation lines that are within parentheses so that they start just to the right of the preceding left parenthesis. However, traditionally, if that resulted in the continuation line extending to the right of the desired right margin, then indent would push it left just far enough to not overrun the margin, if it could do so without making the continuation line start to the left of the current statement indent. That makes for a weird mix of indentations unless one has been completely rigid about never violating the 80-column limit. This behavior has been pretty universally panned by Postgres developers. Hence, disable it with indent's new -lpl switch, so that parenthesized lines are always lined up with the preceding left paren. This patch is much less interesting than the first round of indent changes, but also bulkier, so I thought it best to separate the effects. Discussion: https://postgr.es/m/E1dAmxK-0006EE-1r@gemulon.postgresql.org Discussion: https://postgr.es/m/30527.1495162840@sss.pgh.pa.us
222 lines
5.0 KiB
C
222 lines
5.0 KiB
C
/*
|
|
* contrib/btree_gist/btree_float8.c
|
|
*/
|
|
#include "postgres.h"
|
|
|
|
#include "btree_gist.h"
|
|
#include "btree_utils_num.h"
|
|
|
|
typedef struct float8key
|
|
{
|
|
float8 lower;
|
|
float8 upper;
|
|
} float8KEY;
|
|
|
|
/*
|
|
** float8 ops
|
|
*/
|
|
PG_FUNCTION_INFO_V1(gbt_float8_compress);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_fetch);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_union);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_picksplit);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_consistent);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_distance);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_penalty);
|
|
PG_FUNCTION_INFO_V1(gbt_float8_same);
|
|
|
|
|
|
static bool
|
|
gbt_float8gt(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
return (*((const float8 *) a) > *((const float8 *) b));
|
|
}
|
|
static bool
|
|
gbt_float8ge(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
return (*((const float8 *) a) >= *((const float8 *) b));
|
|
}
|
|
static bool
|
|
gbt_float8eq(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
return (*((const float8 *) a) == *((const float8 *) b));
|
|
}
|
|
static bool
|
|
gbt_float8le(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
return (*((const float8 *) a) <= *((const float8 *) b));
|
|
}
|
|
static bool
|
|
gbt_float8lt(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
return (*((const float8 *) a) < *((const float8 *) b));
|
|
}
|
|
|
|
static int
|
|
gbt_float8key_cmp(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
float8KEY *ia = (float8KEY *) (((const Nsrt *) a)->t);
|
|
float8KEY *ib = (float8KEY *) (((const Nsrt *) b)->t);
|
|
|
|
if (ia->lower == ib->lower)
|
|
{
|
|
if (ia->upper == ib->upper)
|
|
return 0;
|
|
|
|
return (ia->upper > ib->upper) ? 1 : -1;
|
|
}
|
|
|
|
return (ia->lower > ib->lower) ? 1 : -1;
|
|
}
|
|
|
|
static float8
|
|
gbt_float8_dist(const void *a, const void *b, FmgrInfo *flinfo)
|
|
{
|
|
float8 arg1 = *(const float8 *) a;
|
|
float8 arg2 = *(const float8 *) b;
|
|
float8 r;
|
|
|
|
r = arg1 - arg2;
|
|
CHECKFLOATVAL(r, isinf(arg1) || isinf(arg2), true);
|
|
|
|
return Abs(r);
|
|
}
|
|
|
|
|
|
static const gbtree_ninfo tinfo =
|
|
{
|
|
gbt_t_float8,
|
|
sizeof(float8),
|
|
16, /* sizeof(gbtreekey16) */
|
|
gbt_float8gt,
|
|
gbt_float8ge,
|
|
gbt_float8eq,
|
|
gbt_float8le,
|
|
gbt_float8lt,
|
|
gbt_float8key_cmp,
|
|
gbt_float8_dist
|
|
};
|
|
|
|
|
|
PG_FUNCTION_INFO_V1(float8_dist);
|
|
Datum
|
|
float8_dist(PG_FUNCTION_ARGS)
|
|
{
|
|
float8 a = PG_GETARG_FLOAT8(0);
|
|
float8 b = PG_GETARG_FLOAT8(1);
|
|
float8 r;
|
|
|
|
r = a - b;
|
|
CHECKFLOATVAL(r, isinf(a) || isinf(b), true);
|
|
|
|
PG_RETURN_FLOAT8(Abs(r));
|
|
}
|
|
|
|
/**************************************************
|
|
* float8 ops
|
|
**************************************************/
|
|
|
|
|
|
Datum
|
|
gbt_float8_compress(PG_FUNCTION_ARGS)
|
|
{
|
|
GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
|
|
|
|
PG_RETURN_POINTER(gbt_num_compress(entry, &tinfo));
|
|
}
|
|
|
|
Datum
|
|
gbt_float8_fetch(PG_FUNCTION_ARGS)
|
|
{
|
|
GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
|
|
|
|
PG_RETURN_POINTER(gbt_num_fetch(entry, &tinfo));
|
|
}
|
|
|
|
Datum
|
|
gbt_float8_consistent(PG_FUNCTION_ARGS)
|
|
{
|
|
GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
|
|
float8 query = PG_GETARG_FLOAT8(1);
|
|
StrategyNumber strategy = (StrategyNumber) PG_GETARG_UINT16(2);
|
|
|
|
/* Oid subtype = PG_GETARG_OID(3); */
|
|
bool *recheck = (bool *) PG_GETARG_POINTER(4);
|
|
float8KEY *kkk = (float8KEY *) DatumGetPointer(entry->key);
|
|
GBT_NUMKEY_R key;
|
|
|
|
/* All cases served by this function are exact */
|
|
*recheck = false;
|
|
|
|
key.lower = (GBT_NUMKEY *) &kkk->lower;
|
|
key.upper = (GBT_NUMKEY *) &kkk->upper;
|
|
|
|
PG_RETURN_BOOL(
|
|
gbt_num_consistent(&key, (void *) &query, &strategy, GIST_LEAF(entry), &tinfo, fcinfo->flinfo)
|
|
);
|
|
}
|
|
|
|
|
|
Datum
|
|
gbt_float8_distance(PG_FUNCTION_ARGS)
|
|
{
|
|
GISTENTRY *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
|
|
float8 query = PG_GETARG_FLOAT8(1);
|
|
|
|
/* Oid subtype = PG_GETARG_OID(3); */
|
|
float8KEY *kkk = (float8KEY *) DatumGetPointer(entry->key);
|
|
GBT_NUMKEY_R key;
|
|
|
|
key.lower = (GBT_NUMKEY *) &kkk->lower;
|
|
key.upper = (GBT_NUMKEY *) &kkk->upper;
|
|
|
|
PG_RETURN_FLOAT8(
|
|
gbt_num_distance(&key, (void *) &query, GIST_LEAF(entry), &tinfo, fcinfo->flinfo)
|
|
);
|
|
}
|
|
|
|
|
|
Datum
|
|
gbt_float8_union(PG_FUNCTION_ARGS)
|
|
{
|
|
GistEntryVector *entryvec = (GistEntryVector *) PG_GETARG_POINTER(0);
|
|
void *out = palloc(sizeof(float8KEY));
|
|
|
|
*(int *) PG_GETARG_POINTER(1) = sizeof(float8KEY);
|
|
PG_RETURN_POINTER(gbt_num_union((void *) out, entryvec, &tinfo, fcinfo->flinfo));
|
|
}
|
|
|
|
|
|
Datum
|
|
gbt_float8_penalty(PG_FUNCTION_ARGS)
|
|
{
|
|
float8KEY *origentry = (float8KEY *) DatumGetPointer(((GISTENTRY *) PG_GETARG_POINTER(0))->key);
|
|
float8KEY *newentry = (float8KEY *) DatumGetPointer(((GISTENTRY *) PG_GETARG_POINTER(1))->key);
|
|
float *result = (float *) PG_GETARG_POINTER(2);
|
|
|
|
penalty_num(result, origentry->lower, origentry->upper, newentry->lower, newentry->upper);
|
|
|
|
PG_RETURN_POINTER(result);
|
|
|
|
}
|
|
|
|
Datum
|
|
gbt_float8_picksplit(PG_FUNCTION_ARGS)
|
|
{
|
|
PG_RETURN_POINTER(gbt_num_picksplit(
|
|
(GistEntryVector *) PG_GETARG_POINTER(0),
|
|
(GIST_SPLITVEC *) PG_GETARG_POINTER(1),
|
|
&tinfo, fcinfo->flinfo
|
|
));
|
|
}
|
|
|
|
Datum
|
|
gbt_float8_same(PG_FUNCTION_ARGS)
|
|
{
|
|
float8KEY *b1 = (float8KEY *) PG_GETARG_POINTER(0);
|
|
float8KEY *b2 = (float8KEY *) PG_GETARG_POINTER(1);
|
|
bool *result = (bool *) PG_GETARG_POINTER(2);
|
|
|
|
*result = gbt_num_same((void *) b1, (void *) b2, &tinfo, fcinfo->flinfo);
|
|
PG_RETURN_POINTER(result);
|
|
}
|