Add a point in a pointarray. 
- Parameters
- 
  
    | pa | the source POINTARRAY |  | p | the point to add |  | pdims | number of ordinates in p (2..4) |  | where | to insert the point. 0 prepends, pa->npoints appends |  
 
- Returns
- a newly constructed POINTARRAY using a newly allocated buffer for the actual points, or NULL on error. 
Definition at line 503 of file ptarray.c.
  509         LWDEBUGF(3, 
"pa %x p %x size %d where %d",
 
  510                  pa, p, pdims, where);
 
  512         if ( pdims < 2 || pdims > 4 )
 
  514                 lwerror(
"ptarray_addPoint: point dimension out of range (%d)",
 
  521                 lwerror(
"ptarray_addPoint: offset out of range (%d)",
 
  526         LWDEBUG(3, 
"called with a %dD point");
 
  528         pbuf.
x = pbuf.
y = pbuf.
z = pbuf.
m = 0.0;
 
  529         memcpy((
uint8_t *)&pbuf, p, pdims*
sizeof(
double));
 
  531         LWDEBUG(3, 
"initialized point buffer");
 
#define FLAGS_GET_Z(flags)
Macros for manipulating the 'flags' byte.
#define FLAGS_GET_M(flags)
#define LWDEBUG(level, msg)
#define LWDEBUGF(level, msg,...)
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
uint8_t * getPoint_internal(const POINTARRAY *pa, uint32_t n)
POINTARRAY * ptarray_construct(char hasz, char hasm, uint32_t npoints)
Construct an empty pointarray, allocating storage and setting the npoints, but not filling in any inf...
size_t ptarray_point_size(const POINTARRAY *pa)
 
References POINTARRAY::flags, FLAGS_GET_M, FLAGS_GET_Z, getPoint_internal(), LWDEBUG, LWDEBUGF, lwerror(), POINT4D::m, POINTARRAY::npoints, ptarray_construct(), ptarray_point_size(), POINT4D::x, POINT4D::y, and POINT4D::z.
Referenced by lwcircstring_addpoint(), LWGEOM2GEOS(), lwline_make_geos_friendly(), ptarray_close2d(), and ring_make_geos_friendly().