PostGIS  3.1.6dev-r@@SVN_REVISION@@

◆ ARRAY2LWGEOM()

LWGEOM** ARRAY2LWGEOM ( ArrayType *  array,
uint32_t  nelems,
int *  is3d,
int *  srid 
)

Definition at line 2875 of file postgis/lwgeom_geos.c.

2876 {
2877  ArrayIterator iterator;
2878  Datum value;
2879  bool isnull;
2880  bool gotsrid = false;
2881  uint32_t i = 0;
2882 
2883  LWGEOM** lw_geoms = palloc(nelems * sizeof(LWGEOM*));
2884 
2885  iterator = array_create_iterator(array, 0, NULL);
2886 
2887  while (array_iterate(iterator, &value, &isnull))
2888  {
2889  GSERIALIZED *geom = (GSERIALIZED *)DatumGetPointer(value);
2890 
2891  if (isnull)
2892  continue;
2893 
2894  *is3d = *is3d || gserialized_has_z(geom);
2895 
2896  lw_geoms[i] = lwgeom_from_gserialized(geom);
2897  if (!lw_geoms[i]) /* error in creation */
2898  {
2899  lwpgerror("Geometry deserializing geometry");
2900  return NULL;
2901  }
2902  if (!gotsrid)
2903  {
2904  gotsrid = true;
2905  *srid = gserialized_get_srid(geom);
2906  }
2907  else
2908  gserialized_error_if_srid_mismatch_reference(geom, *srid, __func__);
2909 
2910  i++;
2911  }
2912 
2913  return lw_geoms;
2914 }
void gserialized_error_if_srid_mismatch_reference(const GSERIALIZED *g1, const int32_t srid2, const char *funcname)
Definition: gserialized.c:419
int32_t gserialized_get_srid(const GSERIALIZED *g)
Extract the SRID from the serialized form (it is packed into three bytes so this is a handy function)...
Definition: gserialized.c:126
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
Definition: gserialized.c:239
int gserialized_has_z(const GSERIALIZED *g)
Check if a GSERIALIZED has a Z ordinate.
Definition: gserialized.c:174
int value
Definition: genraster.py:62

References gserialized_error_if_srid_mismatch_reference(), gserialized_get_srid(), gserialized_has_z(), lwgeom_from_gserialized(), and genraster::value.

Referenced by cluster_within_distance_garray().

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