chiark / gitweb /
sealing-box: Introduce BoxLocals (nfc)
[reprap-play.git] / sealing-box.scad.m4
index 2cb20f84ccfe0c6a3b1e801403b023f233975674..33b1069ecce0fb45c9a0ee25e2a458d558fa1f5f 100644 (file)
@@ -16,7 +16,9 @@
 //
 // B. Complicated shapes, but harder work
 //      1. Be a .m4 file and m4_include sealing-box.scad.m4
-//      2. Maybe define your own BoxDoShapeRect xxx tbd
+//      2. Define your own BoxDoShapeSomething like BoxDoShapeRect
+//      3. Invoke BoxUseShape
+//      4. Use the Box and Lid modules generated
 
 m4_dnl Box_Part($1=transl_x,$2=transl_y, $3=rot_z,$4=mirror_xy)
 m4_dnl          $5=kind, $6=kindargs, $7=profile(profileargsargs))
@@ -59,10 +61,12 @@ m4_define(`BoxPart_Extrude_Arc',`
     }
 ')
 
-ts_cidoff = (ts_cnrrad * (1-.7) + wallthick * .8) * [1,1];
+m4_define(`BoxLocals',`
+  ts_cidoff = (ts_cnrrad * (1-.7) + wallthick * .8) * [1,1];
 
-ts_xbox_lin = ts_xbox - ts_cnrrad*2;
-ts_ybox_lin = ts_ybox - ts_cnrrad*2;
+  ts_xbox_lin = ts_xbox - ts_cnrrad*2;
+  ts_ybox_lin = ts_ybox - ts_cnrrad*2;
+')
 
 m4_dnl BoxDoShapeRect(`profile(profileargs)');
 m4_define(`BoxDoShapeRect',`
@@ -79,16 +83,19 @@ m4_define(`BoxDoShapeRect',`
 m4_dnl '
 
 module SealingBox_WallProfile(){
+  BoxLocals
   z = ts_zbox - innertube - tubesealrad;
   translate([0, -0.1]) square([wallthick, z]);
   translate([tubesealrad, z]) circle(r=tubesealrad, $fn=20);
 }
 
 module SealingBox_FloorProfile(){
+  BoxLocals
   mirror([0,1]) square([wallthick, floorth]);
 }
 
 module SealingBox_LidProfile(){
+  BoxLocals
   rad = tubesealrad + innertube;
   morex = wallthick;
   difference(){
@@ -111,16 +118,25 @@ module SealingBox_LidProfile(){
 }
 
 module SealingBox_CeilProfile(){
+  BoxLocals
   translate([0, ts_zbox])
     square([wallthick*2, ceilth]);
 }
 
-module TestSealBoxBox(){
-  BoxDoShapeRect(SealingBox_WallProfile(););
-  hull(){ BoxDoShapeRect(SealingBox_FloorProfile();); }
-}
+// BoxDoShape(Basename,BoxDoShapeSomething)
+// generates modules BasenameBox and BasenameLid
+m4_define(`BoxUseShape',`
+  module $1Box(){
+    BoxLocals
+    $2(SealingBox_WallProfile(););
+    hull(){ $2(SealingBox_FloorProfile();); }
+  }
 
-module TestSealBoxLid(){ ////toplevel
-  BoxDoShapeRect(SealingBox_LidProfile(););
-  hull(){ BoxDoShapeRect(SealingBox_CeilProfile();); }
-}
+  module $1Lid(){
+    BoxLocals
+    $2(SealingBox_LidProfile(););
+    hull(){ $2(SealingBox_CeilProfile();); }
+  }
+')
+
+BoxUseShape(`TestSealBox',`BoxDoShapeRect')