1270 GISTENTRY *entry = (GISTENTRY *)PG_GETARG_POINTER(0);
1271 Datum query_datum = PG_GETARG_DATUM(1);
1272 StrategyNumber strategy = (StrategyNumber)PG_GETARG_UINT16(2);
1273 bool *recheck = (
bool *)PG_GETARG_POINTER(4);
1274 char query_box_mem[GIDX_MAX_SIZE];
1275 GIDX *query_box = (GIDX *)query_box_mem;
1279 POSTGIS_DEBUGF(3,
"[GIST] '%s' function called", __func__);
1284 elog(ERROR,
"unrecognized strategy number: %d", strategy);
1285 PG_RETURN_FLOAT8(FLT_MAX);
1289 if (gserialized_datum_get_gidx_p(query_datum, query_box) ==
LW_FAILURE)
1291 POSTGIS_DEBUG(2,
"[GIST] null query_gbox_index!");
1292 PG_RETURN_FLOAT8(FLT_MAX);
1296 if (GIST_LEAF(entry))
1300 entry_box = (GIDX *)PG_DETOAST_DATUM(entry->key);
1308 POSTGIS_DEBUGF(2,
"[GIST] '%s' got distance %g", __func__,
distance);
static double gidx_distance(const GIDX *a, const GIDX *b, int m_is_time)
Calculate the box->box distance.
static double distance(double x1, double y1, double x2, double y2)