PostGIS  2.5.7dev-r@@SVN_REVISION@@

◆ gserialized_datum_predicate()

static int gserialized_datum_predicate ( Datum  gs1,
Datum  gs2,
gidx_predicate  predicate 
)
static

Support function.

Based on two datums return true if they satisfy the predicate and false otherwise.

Definition at line 539 of file gserialized_gist_nd.c.

540 {
541  /* Put aside some stack memory and use it for GIDX pointers. */
542  char boxmem1[GIDX_MAX_SIZE];
543  char boxmem2[GIDX_MAX_SIZE];
544  GIDX *gidx1 = (GIDX*)boxmem1;
545  GIDX *gidx2 = (GIDX*)boxmem2;
546 
547  POSTGIS_DEBUG(3, "entered function");
548 
549  /* Must be able to build box for each arguement (ie, not empty geometry)
550  and predicate function to return true. */
551  if ( (gserialized_datum_get_gidx_p(gs1, gidx1) == LW_SUCCESS) &&
552  (gserialized_datum_get_gidx_p(gs2, gidx2) == LW_SUCCESS) &&
553  predicate(gidx1, gidx2) )
554  {
555  POSTGIS_DEBUGF(3, "got boxes %s and %s", gidx_to_string(gidx1), gidx_to_string(gidx2));
556  return LW_TRUE;
557  }
558  return LW_FALSE;
559 }
#define LW_FALSE
Definition: liblwgeom.h:77
#define LW_SUCCESS
Definition: liblwgeom.h:80
#define LW_TRUE
Return types for functions with status returns.
Definition: liblwgeom.h:76

References LW_FALSE, LW_SUCCESS, and LW_TRUE.

Referenced by gserialized_contains(), gserialized_overlaps(), and gserialized_within().

Here is the caller graph for this function: