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:13 +0200
committerJörg Frings-Fürst <debian@jff-webhosting.net>2020-05-27 14:58:13 +0200
commit265d6934cd70a60228e7a11cfc000aff73dd4701 (patch)
tree610eb753fea70e7f407e751e22697fc8a1ec04bd /app/bin/trkseg.c
parentbd8c21a35fd05fcbdaa95e4c0b7c94c3b97507b6 (diff)
parent359b557176b9bb2ff1aed2082641eed39c358d0d (diff)
Update upstream source from tag 'upstream/5.1.2a'
Update to upstream version '5.1.2a' with Debian dir 4d0d8239e41bb5de5dc968c2a5c6eb9c140bb2f3
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;
}
}