PostGIS  3.0.0dev-r@@SVN_REVISION@@

◆ LWGEOM_line_from_mpoint()

Datum LWGEOM_line_from_mpoint ( PG_FUNCTION_ARGS  )

Definition at line 1348 of file lwgeom_functions_basic.c.

References geometry_serialize(), gserialized_get_type(), lwgeom_as_lwmpoint(), lwgeom_from_gserialized(), LWGEOM_makeline_garray(), lwline_as_lwgeom(), lwline_free(), lwline_from_lwmpoint(), MULTIPOINTTYPE, PG_FUNCTION_INFO_V1(), and LWMPOINT::srid.

Referenced by LWGEOM_collect_garray().

1349 {
1350  GSERIALIZED *ingeom, *result;
1351  LWLINE *lwline;
1352  LWMPOINT *mpoint;
1353 
1354  POSTGIS_DEBUG(2, "LWGEOM_line_from_mpoint called");
1355 
1356  /* Get input GSERIALIZED and deserialize it */
1357  ingeom = PG_GETARG_GSERIALIZED_P(0);
1358 
1359  if ( gserialized_get_type(ingeom) != MULTIPOINTTYPE )
1360  {
1361  elog(ERROR, "makeline: input must be a multipoint");
1362  PG_RETURN_NULL(); /* input is not a multipoint */
1363  }
1364 
1365  mpoint = lwgeom_as_lwmpoint(lwgeom_from_gserialized(ingeom));
1366  lwline = lwline_from_lwmpoint(mpoint->srid, mpoint);
1367  if ( ! lwline )
1368  {
1369  PG_FREE_IF_COPY(ingeom, 0);
1370  elog(ERROR, "makeline: lwline_from_lwmpoint returned NULL");
1371  PG_RETURN_NULL();
1372  }
1373 
1374  result = geometry_serialize(lwline_as_lwgeom(lwline));
1375 
1376  PG_FREE_IF_COPY(ingeom, 0);
1377  lwline_free(lwline);
1378 
1379  PG_RETURN_POINTER(result);
1380 }
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.
#define MULTIPOINTTYPE
Definition: liblwgeom.h:87
void lwline_free(LWLINE *line)
Definition: lwline.c:76
LWGEOM * lwline_as_lwgeom(const LWLINE *obj)
Definition: lwgeom.c:321
LWLINE * lwline_from_lwmpoint(int srid, const LWMPOINT *mpoint)
Definition: lwline.c:284
GSERIALIZED * geometry_serialize(LWGEOM *lwgeom)
LWMPOINT * lwgeom_as_lwmpoint(const LWGEOM *lwgeom)
Definition: lwgeom.c:224
int32_t srid
Definition: liblwgeom.h:469
Here is the call graph for this function:
Here is the caller graph for this function: