diff options
author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2024-11-14 19:35:45 +0100 |
---|---|---|
committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2024-11-14 19:35:45 +0100 |
commit | df5520aa2dae5b3ce7abf8733dcdd152898af163 (patch) | |
tree | 00d3047bfb14f682bfb5a21010c731ed649bfed7 /app/cornu | |
parent | df247efec654e512242e4f4f1b0212034f9e01fe (diff) | |
parent | ec3c0f6f6e7153fa797dc57a0e95779cbc63a23b (diff) |
Merge branch 'release/debian/1_5.3.0GA-1'debian/1_5.3.0GA-1
Diffstat (limited to 'app/cornu')
-rw-r--r-- | app/cornu/CMakeLists.txt | 54 | ||||
-rw-r--r-- | app/cornu/bezctx_xtrkcad.c | 36 |
2 files changed, 41 insertions, 49 deletions
diff --git a/app/cornu/CMakeLists.txt b/app/cornu/CMakeLists.txt index b54fc80..4e7e7d3 100644 --- a/app/cornu/CMakeLists.txt +++ b/app/cornu/CMakeLists.txt @@ -1,27 +1,29 @@ -PROJECT(cornu) - -FILE(GLOB HEADERS *.h) - -SET(SOURCES - bezctx.c - bezctx_xtrkcad.c - spiroentrypoints.c - spiro.c - ) +project(cornu) -SET(HEADERS - spiro.h - ) - - -INCLUDE_DIRECTORIES(${XTrkCAD_BINARY_DIR}) -INCLUDE_DIRECTORIES(${XTrkCAD_SOURCE_DIR}) -INCLUDE_DIRECTORIES(${wlib_SOURCE_DIR}/include) -INCLUDE_DIRECTORIES(${help_BINARY_DIR}) - -ADD_LIBRARY(xtrkcad-cornu ${HEADERS} ${SOURCES}) - - - - - +add_library(xtrkcad-cornu "") + +target_sources(xtrkcad-cornu + PRIVATE + bezctx.c + bezctx_xtrkcad.c + spiroentrypoints.c + spiro.c + bezctx.h + bezctx_intf.h + zmisc.h +) + +target_sources(xtrkcad-cornu + PUBLIC + bezctx_xtrkcad.h + spiroentrypoints.h + spiro.h +) + +target_link_libraries(xtrkcad-cornu + PRIVATE + xtrkcad-wlib + xtrkcad-lib +) + +target_include_directories(xtrkcad-cornu PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}") diff --git a/app/cornu/bezctx_xtrkcad.c b/app/cornu/bezctx_xtrkcad.c index f30e1c2..2e0d8f4 100644 --- a/app/cornu/bezctx_xtrkcad.c +++ b/app/cornu/bezctx_xtrkcad.c @@ -26,6 +26,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA #include "bezctx.h" #include "bezctx_xtrkcad.h" #include "track.h" +#include "draw.h" #include "tbezier.h" #include "i18n.h" #include "math.h" @@ -71,19 +72,16 @@ bezctx_xtrkcad_lineto(bezctx *z, double x, double y) { return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray); seg->u.l.pos[0].x = bc->last_pos.x; seg->u.l.pos[0].y = bc->last_pos.y; seg->u.l.pos[1].x = x; seg->u.l.pos[1].y = y; seg->u.l.option = 0; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_STRTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max =0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSeg_t, seg->bezSegs ); seg->u.l.angle = FindAngle(seg->u.l.pos[0],seg->u.l.pos[1]); bc->last_pos.x = x; bc->last_pos.y = y; @@ -105,7 +103,7 @@ bezctx_xtrkcad_quadto(bezctx *z, double x1, double y1, double x2, double y2) return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray); seg->u.b.pos[0] = bc->last_pos; seg->u.b.pos[1].x = x1; seg->u.b.pos[1].y = y1; @@ -113,13 +111,10 @@ bezctx_xtrkcad_quadto(bezctx *z, double x1, double y1, double x2, double y2) seg->u.b.pos[2].y = y1; seg->u.b.pos[3].x = x2; seg->u.b.pos[3].y = y2; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_BEZTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max =0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSeg_t, seg->bezSegs ); bc->last_pos.x = x2; bc->last_pos.y = y2; @@ -142,7 +137,7 @@ static void return; } DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - trkSeg_p seg = &trkSeg(bc->segsArray->cnt-1); + trkSeg_p seg = &DYNARR_LAST(trkSeg_t, *bc->segsArray); seg->u.b.pos[0].x = bc->last_pos.x; seg->u.b.pos[0].y = bc->last_pos.y; seg->u.b.pos[1].x = x1; @@ -151,13 +146,10 @@ static void seg->u.b.pos[2].y = y2; seg->u.b.pos[3].x = x3; seg->u.b.pos[3].y = y3; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorBlack; seg->type = SEG_BEZTRK; - if (seg->bezSegs.ptr) MyFree(seg->bezSegs.ptr); - seg->bezSegs.max = 0; - seg->bezSegs.cnt = 0; - seg->bezSegs.ptr = NULL; + DYNARR_FREE( trkSegs_t, seg->bezSegs ); bc->last_pos.x = x3; bc->last_pos.y = y3; @@ -165,12 +157,12 @@ static void if (bc->draw_spots) { DYNARR_APPEND(trkSeg_t,* bc->segsArray,10); - seg = &trkSeg(bc->segsArray->cnt-1); + seg = &DYNARR_LAST( trkSeg_t, *bc->segsArray ); seg->type=SEG_FILCRCL; seg->u.c.center.x = bc->last_pos.x; seg->u.c.center.y = bc->last_pos.y; seg->u.c.radius = bc->spot_size; - seg->width = 0.0; + seg->lineWidth = 0.0; seg->color = wDrawColorGrey40; } @@ -207,9 +199,7 @@ new_bezctx_xtrkcad(dynArr_t * segArray, int ends[2], BOOL_T spots, DIST_T spot_s result->spot_size = spot_size; result->track = TRUE; - result->segsArray->cnt =0; - result->segsArray->ptr =0; - result->segsArray->max =0; + DYNARR_INIT( trkSeg_t, *result->segsArray ); return &result->base; |