193{
194 uint32_t i;
197 size_t ptsize, size;
198 uint8_t *newpoints, *ptr;
199
200 if (zmflag == 0) ptsize = 2 * sizeof(double);
201 else if (zmflag == 3) ptsize = 4 * sizeof(double);
202 else ptsize = 3 * sizeof(double);
203
204
205 size = ptsize * mpoint->
ngeoms;
207 memset(newpoints, 0, size);
208
209 ptr = newpoints;
210 for (i = 0; i < mpoint->
ngeoms; i++)
211 {
212 memcpy(ptr,
214 ptsize);
215 ptr += ptsize;
216 }
217
219
220 LWDEBUGF(3,
"lwcurve_from_lwmpoint: constructed pointarray for %d points, %d zmflag", mpoint->
ngeoms, zmflag);
221
223}
POINTARRAY * ptarray_construct_reference_data(char hasz, char hasm, uint32_t npoints, uint8_t *ptlist)
Construct a new POINTARRAY, referencing to the data from ptlist.
void * lwalloc(size_t size)
#define FLAGS_GET_ZM(flags)
LWCIRCSTRING * lwcircstring_construct(int32_t srid, GBOX *bbox, POINTARRAY *points)
#define LWDEBUGF(level, msg,...)
static uint8_t * getPoint_internal(const POINTARRAY *pa, uint32_t n)