mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-19 19:09:36 +00:00
Simplified list_rotate() and polygon_shift()
This commit is contained in:
parent
f19179e232
commit
faea648e66
2 changed files with 2 additions and 6 deletions
|
@ -180,8 +180,7 @@ function reverse(list) =
|
||||||
function list_rotate(list,n=1) =
|
function list_rotate(list,n=1) =
|
||||||
assert(is_list(list)||is_string(list))
|
assert(is_list(list)||is_string(list))
|
||||||
assert(is_num(n))
|
assert(is_num(n))
|
||||||
let(n = posmod(n,len(list)))
|
select(list,n,n+len(list)-1);
|
||||||
n==0? list : concat(select(list,n,-1), select(list,0,n-1));
|
|
||||||
|
|
||||||
|
|
||||||
// Function: deduplicate()
|
// Function: deduplicate()
|
||||||
|
|
|
@ -926,10 +926,7 @@ function polygon_area(vertices) =
|
||||||
// Example:
|
// Example:
|
||||||
// polygon_shift([[3,4], [8,2], [0,2], [-4,0]], 2); // Returns [[0,2], [-4,0], [3,4], [8,2]]
|
// polygon_shift([[3,4], [8,2], [0,2], [-4,0]], 2); // Returns [[0,2], [-4,0], [3,4], [8,2]]
|
||||||
function polygon_shift(poly, i) =
|
function polygon_shift(poly, i) =
|
||||||
assert(i<len(poly))
|
list_rotate(cleanup_path(poly), i);
|
||||||
let(
|
|
||||||
poly = cleanup_path(poly)
|
|
||||||
) select(poly,i,i+len(poly)-1);
|
|
||||||
|
|
||||||
|
|
||||||
// Function: polygon_shift_to_closest_point()
|
// Function: polygon_shift_to_closest_point()
|
||||||
|
|
Loading…
Reference in a new issue