PostGIS  3.0.0dev-r@@SVN_REVISION@@

◆ LWGEOM_makepoly()

Datum LWGEOM_makepoly ( PG_FUNCTION_ARGS  )

Definition at line 1535 of file lwgeom_functions_basic.c.

References geometry_serialize(), gserialized_get_type(), LINETYPE, lwalloc(), lwgeom_as_lwline(), LWGEOM_expand(), lwgeom_from_gserialized(), lwgeom_summary(), lwline_free(), lwpoly_from_lwlines(), and PG_FUNCTION_INFO_V1().

Referenced by LWGEOM_makeline().

1536 {
1537  GSERIALIZED *pglwg1;
1538  ArrayType *array=NULL;
1539  GSERIALIZED *result=NULL;
1540  const LWLINE *shell=NULL;
1541  const LWLINE **holes=NULL;
1542  LWPOLY *outpoly;
1543  uint32 nholes=0;
1544  uint32 i;
1545  size_t offset=0;
1546 
1547  POSTGIS_DEBUG(2, "LWGEOM_makepoly called.");
1548 
1549  /* Get input shell */
1550  pglwg1 = PG_GETARG_GSERIALIZED_P(0);
1551  if ( gserialized_get_type(pglwg1) != LINETYPE )
1552  {
1553  lwpgerror("Shell is not a line");
1554  }
1555  shell = lwgeom_as_lwline(lwgeom_from_gserialized(pglwg1));
1556 
1557  /* Get input holes if any */
1558  if ( PG_NARGS() > 1 )
1559  {
1560  array = PG_GETARG_ARRAYTYPE_P(1);
1561  nholes = ArrayGetNItems(ARR_NDIM(array), ARR_DIMS(array));
1562  holes = lwalloc(sizeof(LWLINE *)*nholes);
1563  for (i=0; i<nholes; i++)
1564  {
1565 #pragma GCC diagnostic push
1566 #pragma GCC diagnostic ignored "-Wsign-compare"
1567  GSERIALIZED *g = (GSERIALIZED *)(ARR_DATA_PTR(array)+offset);
1568 #pragma GCC diagnostic pop
1569  LWLINE *hole;
1570  offset += INTALIGN(VARSIZE(g));
1571  if ( gserialized_get_type(g) != LINETYPE )
1572  {
1573  lwpgerror("Hole %d is not a line", i);
1574  }
1576  holes[i] = hole;
1577  }
1578  }
1579 
1580  outpoly = lwpoly_from_lwlines(shell, nholes, holes);
1581  POSTGIS_DEBUGF(3, "%s", lwgeom_summary((LWGEOM*)outpoly, 0));
1582  result = geometry_serialize((LWGEOM *)outpoly);
1583 
1584  lwline_free((LWLINE*)shell);
1585  PG_FREE_IF_COPY(pglwg1, 0);
1586 
1587  for (i=0; i<nholes; i++)
1588  {
1589  lwline_free((LWLINE*)holes[i]);
1590  }
1591 
1592  PG_RETURN_POINTER(result);
1593 }
#define LINETYPE
Definition: liblwgeom.h:85
uint32_t gserialized_get_type(const GSERIALIZED *s)
Extract the geometry type from the serialized form (it hides in the anonymous data area...
Definition: g_serialized.c:86
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
void lwline_free(LWLINE *line)
Definition: lwline.c:76
LWLINE * lwgeom_as_lwline(const LWGEOM *lwgeom)
Definition: lwgeom.c:161
LWPOLY * lwpoly_from_lwlines(const LWLINE *shell, uint32_t nholes, const LWLINE **holes)
Definition: lwpoly.c:360
GSERIALIZED * geometry_serialize(LWGEOM *lwgeom)
void * lwalloc(size_t size)
Definition: lwutil.c:227
char * lwgeom_summary(const LWGEOM *lwgeom, int offset)
Definition: lwgeom_debug.c:158
Here is the call graph for this function:
Here is the caller graph for this function: