PostGIS  3.4.0dev-r@@SVN_REVISION@@

◆ lwgeom_isfinite()

int lwgeom_isfinite ( const LWGEOM lwgeom)

Check if a LWGEOM has any non-finite (NaN or Inf) coordinates.

Definition at line 2681 of file lwgeom.c.

2682 {
2684  int hasz = lwgeom_has_z(lwgeom);
2685  int hasm = lwgeom_has_m(lwgeom);
2686 
2687  while (lwpointiterator_has_next(it))
2688  {
2689  POINT4D p;
2690  lwpointiterator_next(it, &p);
2691  int finite = isfinite(p.x) &&
2692  isfinite(p.y) &&
2693  (hasz ? isfinite(p.z) : 1) &&
2694  (hasm ? isfinite(p.m) : 1);
2695 
2696  if (!finite)
2697  {
2699  return LW_FALSE;
2700  }
2701  }
2703  return LW_TRUE;
2704 }
#define LW_FALSE
Definition: liblwgeom.h:94
LWPOINTITERATOR * lwpointiterator_create(const LWGEOM *g)
Create a new LWPOINTITERATOR over supplied LWGEOM*.
Definition: lwiterator.c:242
int lwpointiterator_next(LWPOINTITERATOR *s, POINT4D *p)
Attempts to assign the next point in the iterator to p, and advances the iterator to the next point.
Definition: lwiterator.c:210
void lwpointiterator_destroy(LWPOINTITERATOR *s)
Free all memory associated with the iterator.
Definition: lwiterator.c:267
int lwpointiterator_has_next(LWPOINTITERATOR *s)
Returns LW_TRUE if there is another point available in the iterator.
Definition: lwiterator.c:202
#define LW_TRUE
Return types for functions with status returns.
Definition: liblwgeom.h:93
int lwgeom_has_z(const LWGEOM *geom)
Return LW_TRUE if geometry has Z ordinates.
Definition: lwgeom.c:934
int lwgeom_has_m(const LWGEOM *geom)
Return LW_TRUE if geometry has M ordinates.
Definition: lwgeom.c:941
double x
Definition: liblwgeom.h:414
double z
Definition: liblwgeom.h:414
double y
Definition: liblwgeom.h:414

References LW_FALSE, LW_TRUE, lwgeom_has_m(), lwgeom_has_z(), lwpointiterator_create(), lwpointiterator_destroy(), lwpointiterator_has_next(), lwpointiterator_next(), POINT4D::m, POINT4D::x, POINT4D::y, and POINT4D::z.

Referenced by buffer(), geography_bestsrid(), LWGEOM_setpoint_linestring(), LWGEOM_to_latlon(), ST_LargestEmptyCircle(), ST_MaximumInscribedCircle(), and topologypreservesimplify().

Here is the call graph for this function:
Here is the caller graph for this function: