From 0fa53f1b80ec378eb939c02b0886b6100c117f3a Mon Sep 17 00:00:00 2001 From: Garth Minette Date: Sun, 12 Sep 2021 19:12:48 -0700 Subject: [PATCH 1/2] Revert decompose_path() to working code. --- paths.scad | 33 ++------------------------------- 1 file changed, 2 insertions(+), 31 deletions(-) diff --git a/paths.scad b/paths.scad index 35c1f24..c552078 100644 --- a/paths.scad +++ b/paths.scad @@ -777,37 +777,8 @@ function decompose_path(path, closed=true, eps=EPSILON) = path = cleanup_path(path, eps=eps), tagged = _tag_self_crossing_subpaths(path, closed=closed, eps=eps), kept = [for (sub = tagged) if(sub[0] == "O") sub[1]], - completed = [for (frag=kept) if(is_closed_path(frag)) frag], - incomplete = [for (frag=kept) if(!is_closed_path(frag)) frag], - defrag = _path_fast_defragment(incomplete, eps=eps), - completed2 = assemble_path_fragments(defrag, eps=eps) - ) concat(completed2,completed); - - -function _path_fast_defragment(fragments, eps=EPSILON, _done=[]) = - len(fragments)==0? _done : - let( - path = fragments[0], - endpt = last(path), - extenders = [ - for (i = [1:1:len(fragments)-1]) let( - test1 = approx(endpt,fragments[i][0],eps=eps), - test2 = approx(endpt,last(fragments[i]),eps=eps) - ) if (test1 || test2) (test1? i : -1) - ] - ) len(extenders) == 1 && extenders[0] >= 0? _path_fast_defragment( - fragments=[ - concat(list_head(path),fragments[extenders[0]]), - for (i = [1:1:len(fragments)-1]) - if (i != extenders[0]) fragments[i] - ], - eps=eps, - _done=_done - ) : _path_fast_defragment( - fragments=[for (i = [1:1:len(fragments)-1]) fragments[i]], - eps=eps, - _done=concat(_done,[deduplicate(path,closed=true,eps=eps)]) - ); + outregion = assemble_path_fragments(kept, eps=eps) + ) outregion; function _extreme_angle_fragment(seg, fragments, rightmost=true, eps=EPSILON) = From 54038b68d2781221d57ad5604eb3d7aac21e1d79 Mon Sep 17 00:00:00 2001 From: Garth Minette Date: Sun, 12 Sep 2021 19:15:05 -0700 Subject: [PATCH 2/2] Tabs indentation disallowed. --- paths.scad | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/paths.scad b/paths.scad index c552078..00748c3 100644 --- a/paths.scad +++ b/paths.scad @@ -778,7 +778,7 @@ function decompose_path(path, closed=true, eps=EPSILON) = tagged = _tag_self_crossing_subpaths(path, closed=closed, eps=eps), kept = [for (sub = tagged) if(sub[0] == "O") sub[1]], outregion = assemble_path_fragments(kept, eps=eps) - ) outregion; + ) outregion; function _extreme_angle_fragment(seg, fragments, rightmost=true, eps=EPSILON) =