mirror of
https://github.com/postgres/postgres.git
synced 2025-04-20 00:42:27 +03:00
We give results for <, <=, =, >=, and >, not just =. Because why not? Author: Paul A. Jungwirth <pj@illuminatedcomputing.com> Discussion: https://www.postgresql.org/message-id/flat/CA+renyUApHgSZF9-nd-a0+OPGharLQLO=mDHcY4_qQ0+noCUVg@mail.gmail.com
81 lines
1.8 KiB
C
81 lines
1.8 KiB
C
/*
|
|
* contrib/btree_gist/btree_gist.c
|
|
*/
|
|
#include "postgres.h"
|
|
|
|
#include "access/stratnum.h"
|
|
#include "utils/builtins.h"
|
|
|
|
PG_MODULE_MAGIC;
|
|
|
|
PG_FUNCTION_INFO_V1(gbt_decompress);
|
|
PG_FUNCTION_INFO_V1(gbtreekey_in);
|
|
PG_FUNCTION_INFO_V1(gbtreekey_out);
|
|
PG_FUNCTION_INFO_V1(gist_stratnum_btree);
|
|
|
|
/**************************************************
|
|
* In/Out for keys
|
|
**************************************************/
|
|
|
|
|
|
Datum
|
|
gbtreekey_in(PG_FUNCTION_ARGS)
|
|
{
|
|
Oid typioparam = PG_GETARG_OID(1);
|
|
|
|
ereport(ERROR,
|
|
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
|
errmsg("cannot accept a value of type %s",
|
|
format_type_extended(typioparam, -1,
|
|
FORMAT_TYPE_ALLOW_INVALID))));
|
|
|
|
PG_RETURN_VOID(); /* keep compiler quiet */
|
|
}
|
|
|
|
Datum
|
|
gbtreekey_out(PG_FUNCTION_ARGS)
|
|
{
|
|
/* Sadly, we do not receive any indication of the specific type */
|
|
ereport(ERROR,
|
|
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
|
|
errmsg("cannot display a value of type %s", "gbtreekey?")));
|
|
|
|
PG_RETURN_VOID(); /* keep compiler quiet */
|
|
}
|
|
|
|
|
|
/*
|
|
** GiST DeCompress methods
|
|
** do not do anything.
|
|
*/
|
|
Datum
|
|
gbt_decompress(PG_FUNCTION_ARGS)
|
|
{
|
|
PG_RETURN_POINTER(PG_GETARG_POINTER(0));
|
|
}
|
|
|
|
/*
|
|
* Returns the btree number for supported operators, otherwise invalid.
|
|
*/
|
|
Datum
|
|
gist_stratnum_btree(PG_FUNCTION_ARGS)
|
|
{
|
|
StrategyNumber strat = PG_GETARG_UINT16(0);
|
|
|
|
switch (strat)
|
|
{
|
|
case RTEqualStrategyNumber:
|
|
PG_RETURN_UINT16(BTEqualStrategyNumber);
|
|
case RTLessStrategyNumber:
|
|
PG_RETURN_UINT16(BTLessStrategyNumber);
|
|
case RTLessEqualStrategyNumber:
|
|
PG_RETURN_UINT16(BTLessEqualStrategyNumber);
|
|
case RTGreaterStrategyNumber:
|
|
PG_RETURN_UINT16(BTGreaterStrategyNumber);
|
|
case RTGreaterEqualStrategyNumber:
|
|
PG_RETURN_UINT16(BTGreaterEqualStrategyNumber);
|
|
default:
|
|
PG_RETURN_UINT16(InvalidStrategy);
|
|
}
|
|
}
|