Switched to use default_tag("remove")

This commit is contained in:
Richard Milewski 2023-10-03 15:19:52 -07:00
parent 9e735ba364
commit f86a2b851e

View File

@ -1522,7 +1522,7 @@ module show_int(tags)
// Arguments: // Arguments:
// edges = Faces to mask. See [Specifying Faces](attachments.scad#subsection-specifying-faces) for information on specifying faces. Default: All faces // edges = Faces to mask. See [Specifying Faces](attachments.scad#subsection-specifying-faces) for information on specifying faces. Default: All faces
// Side Effects: // Side Effects:
// Tags the children with "remove" (and hence sets `$tag`) if no tag is already set. // Sets the default_tag to "remove".
// `$idx` is set to the index number of each face in the list of faces given. // `$idx` is set to the index number of each face in the list of faces given.
// `$attach_anchor` is set for each face given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each face given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// Example: // Example:
@ -1543,8 +1543,7 @@ module face_mask(faces=[LEFT,RIGHT,FRONT,BACK,BOT,TOP]) {
assert(all([for (face=faces) is_vector(face) && sum([for (x=face) x!=0? 1 : 0])==1]), "Vector in faces doesn't point at a face."); assert(all([for (face=faces) is_vector(face) && sum([for (x=face) x!=0? 1 : 0])==1]), "Vector in faces doesn't point at a face.");
assert($parent_geom != undef, "No object to attach to!"); assert($parent_geom != undef, "No object to attach to!");
attach(faces) { attach(faces) {
if ($tag=="") tag("remove") children(); default_tag("remove") children();
else children();
} }
} }
@ -1575,9 +1574,7 @@ module face_mask(faces=[LEFT,RIGHT,FRONT,BACK,BOT,TOP]) {
// edges = Edges to mask. See [Specifying Edges](attachments.scad#subsection-specifying-edges). Default: All edges. // edges = Edges to mask. See [Specifying Edges](attachments.scad#subsection-specifying-edges). Default: All edges.
// except = Edges to explicitly NOT mask. See [Specifying Edges](attachments.scad#subsection-specifying-edges). Default: No edges. // except = Edges to explicitly NOT mask. See [Specifying Edges](attachments.scad#subsection-specifying-edges). Default: No edges.
// Side Effects: // Side Effects:
// Tags the children with "remove" (and hence sets `$tag`) if no tag is already set. // Sets the default_tag to "remove".
// Side Effects:
// Tags the children with "remove" (and hence sets `$tag`) if no tag is already set.
// `$idx` is set to the index number of each edge. // `$idx` is set to the index number of each edge.
// `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// Example: // Example:
@ -1608,8 +1605,7 @@ module edge_mask(edges=EDGES_ALL, except=[]) {
vec.z==0 && sign(vec.x)!=sign(vec.y)? [0,180,45+v_theta(vec)] : vec.z==0 && sign(vec.x)!=sign(vec.y)? [0,180,45+v_theta(vec)] :
[-90,0,180+v_theta(vec)]; [-90,0,180+v_theta(vec)];
translate(anch[1]) rot(rotang) translate(anch[1]) rot(rotang)
if ($tag=="") tag("remove") children(); default_tag("remove") children();
else children();
} }
} }
@ -1631,7 +1627,7 @@ module edge_mask(edges=EDGES_ALL, except=[]) {
// corners = Corners to mask. See [Specifying Corners](attachments.scad#subsection-specifying-corners). Default: All corners. // corners = Corners to mask. See [Specifying Corners](attachments.scad#subsection-specifying-corners). Default: All corners.
// except = Corners to explicitly NOT mask. See [Specifying Corners](attachments.scad#subsection-specifying-corners). Default: No corners. // except = Corners to explicitly NOT mask. See [Specifying Corners](attachments.scad#subsection-specifying-corners). Default: No corners.
// Side Effects: // Side Effects:
// Tags the children with "remove" (and hence sets `$tag`) if no tag is already set. // Sets the default_tag to "remove".
// `$idx` is set to the index number of each corner. // `$idx` is set to the index number of each corner.
// `$attach_anchor` is set for each corner given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each corner given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// Example: // Example:
@ -1659,8 +1655,7 @@ module corner_mask(corners=CORNERS_ALL, except=[]) {
[ 0,0,180+v_theta(vec)-45] : [ 0,0,180+v_theta(vec)-45] :
[180,0,-90+v_theta(vec)-45]; [180,0,-90+v_theta(vec)-45];
translate(anch[1]) rot(rotang) translate(anch[1]) rot(rotang)
if ($tag=="") tag("remove") children(); default_tag("remove") children();
else children();
} }
} }
@ -1826,7 +1821,7 @@ module edge_profile(edges=EDGES_ALL, except=[], excess=0.01, convexity=10) {
// corner_type = Specifies how exterior corners should be formed. Must be one of `"none"`, `"chamfer"`, `"round"`, or `"sharp"`. Default: `"none"` // corner_type = Specifies how exterior corners should be formed. Must be one of `"none"`, `"chamfer"`, `"round"`, or `"sharp"`. Default: `"none"`
// size = If given the width and height of the 2D profile, will enable rounding and chamfering of internal corners when given a negative profile. // size = If given the width and height of the 2D profile, will enable rounding and chamfering of internal corners when given a negative profile.
// Side Effects: // Side Effects:
// Tags the children with "remove" (and hence sets `$tag`) if no tag is already set. // Sets the default_tag to "remove".
// `$idx` is set to the index number of each edge. // `$idx` is set to the index number of each edge.
// `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// `$profile_type` is set to `"edge"`. // `$profile_type` is set to `"edge"`.
@ -2167,7 +2162,7 @@ module edge_profile_asym(
// d = Diameter of corner mask. // d = Diameter of corner mask.
// convexity = Max number of times a line could intersect the perimeter of the mask shape. Default: 10 // convexity = Max number of times a line could intersect the perimeter of the mask shape. Default: 10
// Side Effects: // Side Effects:
// Tags the children with "remove" (and hence sets $tag) if no tag is already set. // Sets the default_tag to "remove".
// `$idx` is set to the index number of each corner. // `$idx` is set to the index number of each corner.
// `$attach_anchor` is set for each corner given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each corner given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// `$profile_type` is set to `"corner"`. // `$profile_type` is set to `"corner"`.
@ -2195,21 +2190,22 @@ module corner_profile(corners=CORNERS_ALL, except=[], r, d, convexity=10) {
rotang = vec.z<0? rotang = vec.z<0?
[ 0,0,180+v_theta(vec)-45] : [ 0,0,180+v_theta(vec)-45] :
[180,0,-90+v_theta(vec)-45]; [180,0,-90+v_theta(vec)-45];
$tag = $tag=="" ? str($tag_prefix,"remove") : $tag; default_tag("remove"){
translate(anch[1]) { translate(anch[1]) {
rot(rotang) { rot(rotang) {
down(0.01) { down(0.01) {
linear_extrude(height=r+0.01, center=false) { linear_extrude(height=r+0.01, center=false) {
difference() { difference() {
translate(-[0.01,0.01]) square(r); translate(-[0.01,0.01]) square(r);
translate([r,r]) circle(r=r*0.999); translate([r,r]) circle(r=r*0.999);
}
} }
} }
} translate([r,r]) zrot(180) {
translate([r,r]) zrot(180) { rotate_extrude(angle=90, convexity=convexity) {
rotate_extrude(angle=90, convexity=convexity) { right(r) xflip() {
right(r) xflip() { children();
children(); }
} }
} }
} }