PostGIS  2.4.9dev-r@@SVN_REVISION@@

◆ ptarray_clone_deep()

POINTARRAY* ptarray_clone_deep ( const POINTARRAY ptarray)

Deep clone a pointarray (also clones serialized pointlist)

Definition at line 630 of file ptarray.c.

References POINTARRAY::flags, FLAGS_SET_READONLY, lwalloc(), LWDEBUG, POINTARRAY::maxpoints, POINTARRAY::npoints, ptarray_point_size(), and POINTARRAY::serialized_pointlist.

Referenced by _lwt_AddFaceSplit(), _lwt_EdgeMotionArea(), _lwt_HealEdges(), lwcurvepoly_construct_from_lwpoly(), lwcurvepoly_linearize(), LWGEOM_dump_rings(), lwline_clone_deep(), lwmcurve_linearize(), lwmsurface_linearize(), lwpoly_clone_deep(), lwpoly_from_lwlines(), lwtriangle_from_lwline(), parse_kml_coordinates(), and ptarray_remove_repeated_points_minpoints().

631 {
632  POINTARRAY *out = lwalloc(sizeof(POINTARRAY));
633 
634  LWDEBUG(3, "ptarray_clone_deep called.");
635 
636  out->flags = in->flags;
637  out->npoints = in->npoints;
638  out->maxpoints = in->npoints;
639 
640  FLAGS_SET_READONLY(out->flags, 0);
641 
642  if (!in->npoints)
643  {
644  // Avoid calling lwalloc of 0 bytes
645  out->serialized_pointlist = NULL;
646  }
647  else
648  {
649  size_t size = in->npoints * ptarray_point_size(in);
650  out->serialized_pointlist = lwalloc(size);
651  memcpy(out->serialized_pointlist, in->serialized_pointlist, size);
652  }
653 
654  return out;
655 }
uint8_t * serialized_pointlist
Definition: liblwgeom.h:366
int ptarray_point_size(const POINTARRAY *pa)
Definition: ptarray.c:54
int npoints
Definition: liblwgeom.h:371
#define LWDEBUG(level, msg)
Definition: lwgeom_log.h:83
uint8_t flags
Definition: liblwgeom.h:369
int maxpoints
Definition: liblwgeom.h:372
void * lwalloc(size_t size)
Definition: lwutil.c:229
#define FLAGS_SET_READONLY(flags, value)
Definition: liblwgeom.h:150
Here is the call graph for this function:
Here is the caller graph for this function: