summaryrefslogtreecommitdiff
path: root/app/bin/trkseg.c
diff options
context:
space:
mode:
authorJörg Frings-Fürst <debian@jff-webhosting.net>2020-05-27 14:58:02 +0200
committerJörg Frings-Fürst <debian@jff-webhosting.net>2020-05-27 14:58:02 +0200
commit359b557176b9bb2ff1aed2082641eed39c358d0d (patch)
treef6c2baca2e6a5d06b7bf32e48e475a6b7b1ea262 /app/bin/trkseg.c
parent9a1d6eded2750572e9f5f79e53ec507dd7a06ba5 (diff)
New upstream version 5.1.2aupstream/5.1.2a
Diffstat (limited to 'app/bin/trkseg.c')
-rw-r--r--app/bin/trkseg.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/app/bin/trkseg.c b/app/bin/trkseg.c
index 97de5e8..ab4b5a8 100644
--- a/app/bin/trkseg.c
+++ b/app/bin/trkseg.c
@@ -537,13 +537,14 @@ EXPORT void FlipSegs(
break;
case SEG_POLY:
case SEG_FILPOLY:
- pts = (coOrd*)MyMalloc( s->u.p.cnt * sizeof *(coOrd*)NULL );
- memcpy( pts, s->u.p.pts, s->u.p.cnt * sizeof *(coOrd*)NULL );
+ pts = (coOrd*)MyMalloc( s->u.p.cnt * sizeof (coOrd) );
+ memcpy( pts, s->u.p.pts, s->u.p.cnt * sizeof (coOrd) );
s->u.p.pts = pts;
for (inx=0; inx<s->u.p.cnt; inx++) {
s->u.p.pts[inx].y = -s->u.p.pts[inx].y;
}
- MyFree(pts);
+ /* Don't Free - we only just got! ALso can't free other copy as that may be a template */
+ //MyFree(pts);
break;
case SEG_JNTTRK:
s->u.j.pos.y = - s->u.j.pos.y;
@@ -645,14 +646,14 @@ EXPORT void CloneFilledDraw(
switch (sp->type) {
case SEG_POLY:
case SEG_FILPOLY:
- newPts = (coOrd*)MyMalloc( sp->u.p.cnt * sizeof *(coOrd*)0 );
+ newPts = (coOrd*)MyMalloc( sp->u.p.cnt * sizeof (coOrd) );
if ( reorigin ) {
for ( inx = 0; inx<sp->u.p.cnt; inx++ )
REORIGIN( newPts[inx], sp->u.p.pts[inx], sp->u.p.angle, sp->u.p.orig );
sp->u.p.angle = 0;
sp->u.p.orig = zero;
} else {
- memcpy( newPts, sp->u.p.pts, sp->u.p.cnt * sizeof *(coOrd*)0 );
+ memcpy( newPts, sp->u.p.pts, sp->u.p.cnt * sizeof (coOrd) );
}
//if (sp->u.p.pts) Can't do this a pts could be pointing at static
// free(sp->u.p.pts);
@@ -664,7 +665,7 @@ EXPORT void CloneFilledDraw(
case SEG_BEZTRK:
case SEG_BEZLIN:
sp->bezSegs.cnt = 0;
- if (sp->bezSegs.ptr) MyFree(sp->bezSegs.ptr);
+ //if (sp->bezSegs.ptr) MyFree(sp->bezSegs.ptr); Make sure no update to static
sp->bezSegs.ptr = NULL;
sp->bezSegs.max = 0;
FixUpBezierSeg(sp->u.b.pos,sp,sp->type == SEG_BEZTRK);
@@ -1356,7 +1357,7 @@ EXPORT BOOL_T ReadSegs( void )
}
}
s->color = wDrawFindColor( rgb );
- s->u.p.pts = (coOrd*)MyMalloc( s->u.p.cnt * sizeof *(coOrd*)NULL );
+ s->u.p.pts = (coOrd*)MyMalloc( s->u.p.cnt * sizeof (coOrd) );
for ( i=0; i<s->u.p.cnt; i++ ) {
cp = GetNextLine();
if (cp == NULL || !GetArgs( cp, "p", &s->u.p.pts[i])) {
@@ -2034,7 +2035,7 @@ EXPORT void CopyPoly(trkSeg_p p, wIndex_t segCnt) {
coOrd * newPts;
for (int i=0;i<segCnt;i++,p++) {
if (p->type == SEG_POLY || p->type == SEG_FILPOLY) {
- newPts = memdup( p->u.p.pts, p->u.p.cnt*sizeof *(coOrd*)0 );
+ newPts = memdup( p->u.p.pts, p->u.p.cnt*sizeof (coOrd) );
p->u.p.pts = newPts;
}
}