Header And Logo

PostgreSQL
| The world's most advanced open source database.

Data Structures | Typedefs | Functions | Variables

btree_int4.c File Reference

#include "postgres.h"
#include "btree_gist.h"
#include "btree_utils_num.h"
Include dependency graph for btree_int4.c:

Go to the source code of this file.

Data Structures

struct  int32key

Typedefs

typedef struct int32key int32KEY

Functions

 PG_FUNCTION_INFO_V1 (gbt_int4_compress)
 PG_FUNCTION_INFO_V1 (gbt_int4_union)
 PG_FUNCTION_INFO_V1 (gbt_int4_picksplit)
 PG_FUNCTION_INFO_V1 (gbt_int4_consistent)
 PG_FUNCTION_INFO_V1 (gbt_int4_distance)
 PG_FUNCTION_INFO_V1 (gbt_int4_penalty)
 PG_FUNCTION_INFO_V1 (gbt_int4_same)
Datum gbt_int4_compress (PG_FUNCTION_ARGS)
Datum gbt_int4_union (PG_FUNCTION_ARGS)
Datum gbt_int4_picksplit (PG_FUNCTION_ARGS)
Datum gbt_int4_consistent (PG_FUNCTION_ARGS)
Datum gbt_int4_distance (PG_FUNCTION_ARGS)
Datum gbt_int4_penalty (PG_FUNCTION_ARGS)
Datum gbt_int4_same (PG_FUNCTION_ARGS)
static bool gbt_int4gt (const void *a, const void *b)
static bool gbt_int4ge (const void *a, const void *b)
static bool gbt_int4eq (const void *a, const void *b)
static bool gbt_int4le (const void *a, const void *b)
static bool gbt_int4lt (const void *a, const void *b)
static int gbt_int4key_cmp (const void *a, const void *b)
static float8 gbt_int4_dist (const void *a, const void *b)
 PG_FUNCTION_INFO_V1 (int4_dist)
Datum int4_dist (PG_FUNCTION_ARGS)

Variables

static const gbtree_ninfo tinfo

Typedef Documentation

typedef struct int32key int32KEY

Function Documentation

Datum gbt_int4_compress ( PG_FUNCTION_ARGS   ) 

Definition at line 128 of file btree_int4.c.

References gbt_num_compress(), PG_GETARG_POINTER, and PG_RETURN_POINTER.

{
    GISTENTRY  *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
    GISTENTRY  *retval = NULL;

    PG_RETURN_POINTER(gbt_num_compress(retval, entry, &tinfo));
}

Datum gbt_int4_consistent ( PG_FUNCTION_ARGS   ) 

Definition at line 138 of file btree_int4.c.

References DatumGetPointer, gbt_num_consistent(), GIST_LEAF, GISTENTRY::key, int32key::lower, GBT_NUMKEY_R::lower, PG_GETARG_INT32, PG_GETARG_POINTER, PG_GETARG_UINT16, PG_RETURN_BOOL, int32key::upper, and GBT_NUMKEY_R::upper.

{
    GISTENTRY  *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
    int32       query = PG_GETARG_INT32(1);
    StrategyNumber strategy = (StrategyNumber) PG_GETARG_UINT16(2);

    /* Oid      subtype = PG_GETARG_OID(3); */
    bool       *recheck = (bool *) PG_GETARG_POINTER(4);
    int32KEY   *kkk = (int32KEY *) 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)
        );
}

static float8 gbt_int4_dist ( const void *  a,
const void *  b 
) [static]

Definition at line 79 of file btree_int4.c.

References GET_FLOAT_DISTANCE.

{
    return GET_FLOAT_DISTANCE(int32, a, b);
}

Datum gbt_int4_distance ( PG_FUNCTION_ARGS   ) 

Definition at line 162 of file btree_int4.c.

References DatumGetPointer, gbt_num_distance(), GIST_LEAF, GISTENTRY::key, int32key::lower, GBT_NUMKEY_R::lower, PG_GETARG_INT32, PG_GETARG_POINTER, PG_RETURN_FLOAT8, int32key::upper, and GBT_NUMKEY_R::upper.

{
    GISTENTRY  *entry = (GISTENTRY *) PG_GETARG_POINTER(0);
    int32       query = PG_GETARG_INT32(1);

    /* Oid      subtype = PG_GETARG_OID(3); */
    int32KEY   *kkk = (int32KEY *) 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)
        );
}

Datum gbt_int4_penalty ( PG_FUNCTION_ARGS   ) 

Definition at line 192 of file btree_int4.c.

References DatumGetPointer, int32key::lower, penalty_num, PG_GETARG_POINTER, PG_RETURN_POINTER, and int32key::upper.

{
    int32KEY   *origentry = (int32KEY *) DatumGetPointer(((GISTENTRY *) PG_GETARG_POINTER(0))->key);
    int32KEY   *newentry = (int32KEY *) 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_int4_picksplit ( PG_FUNCTION_ARGS   ) 
Datum gbt_int4_same ( PG_FUNCTION_ARGS   ) 

Definition at line 214 of file btree_int4.c.

References gbt_num_same(), PG_GETARG_POINTER, and PG_RETURN_POINTER.

{
    int32KEY   *b1 = (int32KEY *) PG_GETARG_POINTER(0);
    int32KEY   *b2 = (int32KEY *) PG_GETARG_POINTER(1);
    bool       *result = (bool *) PG_GETARG_POINTER(2);

    *result = gbt_num_same((void *) b1, (void *) b2, &tinfo);
    PG_RETURN_POINTER(result);
}

Datum gbt_int4_union ( PG_FUNCTION_ARGS   ) 

Definition at line 181 of file btree_int4.c.

References gbt_num_union(), palloc(), PG_GETARG_POINTER, and PG_RETURN_POINTER.

{
    GistEntryVector *entryvec = (GistEntryVector *) PG_GETARG_POINTER(0);
    void       *out = palloc(sizeof(int32KEY));

    *(int *) PG_GETARG_POINTER(1) = sizeof(int32KEY);
    PG_RETURN_POINTER(gbt_num_union((void *) out, entryvec, &tinfo));
}

static bool gbt_int4eq ( const void *  a,
const void *  b 
) [static]

Definition at line 46 of file btree_int4.c.

{
    return (*((const int32 *) a) == *((const int32 *) b));
}

static bool gbt_int4ge ( const void *  a,
const void *  b 
) [static]

Definition at line 41 of file btree_int4.c.

{
    return (*((const int32 *) a) >= *((const int32 *) b));
}

static bool gbt_int4gt ( const void *  a,
const void *  b 
) [static]

Definition at line 36 of file btree_int4.c.

{
    return (*((const int32 *) a) > *((const int32 *) b));
}

static int gbt_int4key_cmp ( const void *  a,
const void *  b 
) [static]

Definition at line 62 of file btree_int4.c.

References int32key::lower, and int32key::upper.

{
    int32KEY   *ia = (int32KEY *) (((const Nsrt *) a)->t);
    int32KEY   *ib = (int32KEY *) (((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 bool gbt_int4le ( const void *  a,
const void *  b 
) [static]

Definition at line 51 of file btree_int4.c.

{
    return (*((const int32 *) a) <= *((const int32 *) b));
}

static bool gbt_int4lt ( const void *  a,
const void *  b 
) [static]

Definition at line 56 of file btree_int4.c.

{
    return (*((const int32 *) a) < *((const int32 *) b));
}

Datum int4_dist ( PG_FUNCTION_ARGS   ) 

Definition at line 102 of file btree_int4.c.

References Abs, ereport, errcode(), errmsg(), ERROR, PG_GETARG_INT32, PG_RETURN_INT32, and SAMESIGN.

{
    int32       a = PG_GETARG_INT32(0);
    int32       b = PG_GETARG_INT32(1);
    int32       r;
    int32       ra;

    r = a - b;
    ra = Abs(r);

    /* Overflow check. */
    if (ra < 0 || (!SAMESIGN(a, b) && !SAMESIGN(r, a)))
        ereport(ERROR,
                (errcode(ERRCODE_NUMERIC_VALUE_OUT_OF_RANGE),
                 errmsg("integer out of range")));

    PG_RETURN_INT32(ra);
}

PG_FUNCTION_INFO_V1 ( gbt_int4_consistent   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_compress   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_union   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_same   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_penalty   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_picksplit   ) 
PG_FUNCTION_INFO_V1 ( gbt_int4_distance   ) 
PG_FUNCTION_INFO_V1 ( int4_dist   ) 

Variable Documentation

const gbtree_ninfo tinfo [static]
Initial value:

Definition at line 85 of file btree_int4.c.