2375{
2379
2380 POSTGIS_DEBUG(2, "LWGEOM_removepoint called.");
2381
2382 pglwg1 = PG_GETARG_GSERIALIZED_P(0);
2383 which = PG_GETARG_INT32(1);
2384
2386 {
2387 elog(ERROR, "First argument must be a LINESTRING");
2388 PG_RETURN_NULL();
2389 }
2390
2392
2393 if (which < 0 || (uint32_t)which > line->
points->
npoints - 1)
2394 {
2395 elog(ERROR,
"Point index out of range (%u..%u)", 0, line->
points->
npoints - 1);
2396 PG_RETURN_NULL();
2397 }
2398
2400 {
2401 elog(ERROR, "Can't remove points from a single segment line");
2402 PG_RETURN_NULL();
2403 }
2404
2406
2408
2411
2412 PG_FREE_IF_COPY(pglwg1, 0);
2413 PG_RETURN_POINTER(
result);
2414}
char result[OUT_DOUBLE_BUFFER_SIZE]
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
uint32_t gserialized_get_type(const GSERIALIZED *g)
Extract the geometry type from the serialized form (it hides in the anonymous data area,...
LWLINE * lwline_removepoint(LWLINE *line, uint32_t which)
LWLINE * lwgeom_as_lwline(const LWGEOM *lwgeom)
void lwline_free(LWLINE *line)