Merge pull request #360 from adrianVmariano/master

no_function, no_module
This commit is contained in:
Revar Desmera 2021-01-03 20:17:32 -08:00 committed by GitHub
commit c8d7d6dc77
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 6 deletions

View file

@ -446,6 +446,26 @@ module no_children(count) {
assert(count==0, str("Module ",parent_module(1),"() does not support child modules")); assert(count==0, str("Module ",parent_module(1),"() does not support child modules"));
} }
// Function: no_function()
// Usage:
// dummy = no_function(name)
// Description:
// Asserts that the function, "name", only exists as a module.
// Example:
//
function no_function(name) =
assert(false,str("You called ",name,"() as a function, but it is available only as a module"));
// Module: no_module()
// Usage:
// no_module();
// Description:
// Asserts that the called module exists only as a function.
module no_module() {
assert(false, str("You called ",parent_module(1),"() as a module but it is available only as a function"));
}
// Section: Testing Helpers // Section: Testing Helpers

View file

@ -524,8 +524,8 @@ function echo_matrix(M,description,sig=4,eps=1e-9) =
horiz_line = chr(8213), horiz_line = chr(8213),
matstr = matrix_strings(M,sig=sig,eps=eps), matstr = matrix_strings(M,sig=sig,eps=eps),
separator = str_join(repeat(horiz_line,10)), separator = str_join(repeat(horiz_line,10)),
dummy1=echo(str(separator," ",is_def(description) ? description : "")), dummy=echo(str(separator," ",is_def(description) ? description : ""))
dummy2=[for(row=matstr) echo(row)] [for(row=matstr) echo(row)]
) )
echo(separator); echo(separator);
@ -535,5 +535,4 @@ module echo_matrix(M,description,sig=4,eps=1e-9)
} }
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap // vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap

View file

@ -192,6 +192,7 @@ include <structs.scad>
// // Try changing the value to see the effect. // // Try changing the value to see the effect.
// rpath = round_corners(path3d, joint=rounding, k=1, method="smooth", closed=false); // rpath = round_corners(path3d, joint=rounding, k=1, method="smooth", closed=false);
// path_sweep( regular_ngon(n=36, or=.1), rpath); // path_sweep( regular_ngon(n=36, or=.1), rpath);
module round_corners(path, method="circle", radius, cut, joint, k, closed=true, verbose=false) {no_module();}
function round_corners(path, method="circle", radius, cut, joint, k, closed=true, verbose=false) = function round_corners(path, method="circle", radius, cut, joint, k, closed=true, verbose=false) =
assert(in_list(method,["circle", "smooth", "chamfer"]), "method must be one of \"circle\", \"smooth\" or \"chamfer\"") assert(in_list(method,["circle", "smooth", "chamfer"]), "method must be one of \"circle\", \"smooth\" or \"chamfer\"")
let( let(
@ -455,6 +456,7 @@ function _rounding_offsets(edgespec,z_dir=1) =
// pts = [[-3.3, 1.7], [-3.7, -2.2], [3.8, -4.8], [-0.9, -2.4]]; // pts = [[-3.3, 1.7], [-3.7, -2.2], [3.8, -4.8], [-0.9, -2.4]];
// stroke(smooth_path(pts, uniform=false, relsize=0.1),width=.1); // stroke(smooth_path(pts, uniform=false, relsize=0.1),width=.1);
// color("red")move_copies(pts)circle(r=.15,$fn=12); // color("red")move_copies(pts)circle(r=.15,$fn=12);
module smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false, closed=false) {no_module();}
function smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false, closed=false) = function smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false, closed=false) =
let ( let (
bez = path_to_bezier(path, tangents=tangents, size=size, relsize=relsize, uniform=uniform, closed=closed) bez = path_to_bezier(path, tangents=tangents, size=size, relsize=relsize, uniform=uniform, closed=closed)
@ -562,7 +564,7 @@ function _scalar_to_vector(value,length,varname) =
// Example(2D): With a single path with closed=true the start and end junction is rounded. // Example(2D): With a single path with closed=true the start and end junction is rounded.
// tri = regular_ngon(n=3, r=7); // tri = regular_ngon(n=3, r=7);
// stroke(path_join([tri], joint=3,closed=true,$fn=12),closed=true,width=.5); // stroke(path_join([tri], joint=3,closed=true,$fn=12),closed=true,width=.5);
module path_join(paths,joint=0,k=0.5,relocate=true,closed=false) { no_module();}
function path_join(paths,joint=0,k=0.5,relocate=true,closed=false)= function path_join(paths,joint=0,k=0.5,relocate=true,closed=false)=
assert(is_list(paths),"Input paths must be a list of paths") assert(is_list(paths),"Input paths must be a list of paths")
let( let(
@ -1157,6 +1159,15 @@ function os_mask(mask, out=false, extra,check_valid, quality, offset_maxstep, of
// right(50) linear_extrude(height=7) star(5,r=22,ir=13); // right(50) linear_extrude(height=7) star(5,r=22,ir=13);
// convex_offset_extrude(bottom = os_chamfer(height=-2), top=os_chamfer(height=1), height=7) // convex_offset_extrude(bottom = os_chamfer(height=-2), top=os_chamfer(height=1), height=7)
// star(5,r=22,ir=13); // star(5,r=22,ir=13);
function convex_offset_extrude(
height, h, l,
top=[], bottom=[],
offset="round", r=0, steps=16,
extra=0,
cut=undef, chamfer_width=undef, chamfer_height=undef,
joint=undef, k=0.75, angle=45,
convexity=10, thickness = 1/1024
) = no_function("convex_offset_extrude");
module convex_offset_extrude( module convex_offset_extrude(
height, h, l, height, h, l,
top=[], bottom=[], top=[], bottom=[],
@ -1247,8 +1258,11 @@ function _remove_undefined_vals(list) =
// Function&Module: offset_stroke() // Function&Module: offset_stroke()
// Usage: // Usage: as module
// offset_stroke(path, [width], [rounded], [chamfer], [start], [end], [check_valid], [quality], [maxstep], [closed]) // offset_stroke(path, [width], [rounded], [chamfer], [start], [end], [check_valid], [quality], [maxstep], [closed])
// Usage: as function
// path = offset_stroke(path, closed=false, [width], [rounded], [chamfer], [start], [end], [check_valid], [quality], [maxstep])
// region = offset_stroke(path, closed=true, [width], [rounded], [chamfer], [start], [end], [check_valid], [quality], [maxstep])
// Description: // Description:
// Uses `offset()` to compute a stroke for the input path. Unlike `stroke`, the result does not need to be // Uses `offset()` to compute a stroke for the input path. Unlike `stroke`, the result does not need to be
// centered on the input path. The corners can be rounded, pointed, or chamfered, and you can make the ends // centered on the input path. The corners can be rounded, pointed, or chamfered, and you can make the ends
@ -2172,7 +2186,7 @@ function _circle_mask(r) =
// bent_cutout_mask(diam/2-wall/2, wall+.1, subdivide_path(apply(back(10),slot(15, 29, 7)),250)); // bent_cutout_mask(diam/2-wall/2, wall+.1, subdivide_path(apply(back(10),slot(15, 29, 7)),250));
// } // }
// } // }
function bent_cutout_mask(r, thickness, path, convexity=10) = no_function("bent_cutout_mask");
module bent_cutout_mask(r, thickness, path, convexity=10) module bent_cutout_mask(r, thickness, path, convexity=10)
{ {
no_children($children); no_children($children);