PostGIS  2.5.0dev-r@@SVN_REVISION@@
int lwpoly_is_closed ( const LWPOLY poly)

Definition at line 504 of file lwpoly.c.

References LWPOLY::flags, FLAGS_GET_Z, LW_FALSE, LW_TRUE, LWPOLY::nrings, ptarray_is_closed_2d(), ptarray_is_closed_3d(), and LWPOLY::rings.

Referenced by lwgeom_is_closed().

505 {
506  uint32_t i = 0;
507 
508  if ( poly->nrings == 0 )
509  return LW_TRUE;
510 
511  for ( i = 0; i < poly->nrings; i++ )
512  {
513  if (FLAGS_GET_Z(poly->flags))
514  {
515  if ( ! ptarray_is_closed_3d(poly->rings[i]) )
516  return LW_FALSE;
517  }
518  else
519  {
520  if ( ! ptarray_is_closed_2d(poly->rings[i]) )
521  return LW_FALSE;
522  }
523  }
524 
525  return LW_TRUE;
526 }
int ptarray_is_closed_3d(const POINTARRAY *pa)
Definition: ptarray.c:701
int ptarray_is_closed_2d(const POINTARRAY *pa)
Definition: ptarray.c:688
uint32_t nrings
Definition: liblwgeom.h:454
unsigned int uint32_t
Definition: uthash.h:78
#define LW_FALSE
Definition: liblwgeom.h:76
#define LW_TRUE
Return types for functions with status returns.
Definition: liblwgeom.h:75
POINTARRAY ** rings
Definition: liblwgeom.h:456
#define FLAGS_GET_Z(flags)
Macros for manipulating the 'flags' byte.
Definition: liblwgeom.h:139
uint8_t flags
Definition: liblwgeom.h:451

Here is the call graph for this function:

Here is the caller graph for this function: