+ sidemidx = minsideout + screwcsinkdia/2;
+
+ difference(){
+ mirror([0,0,1]) {
+ translate([minx, -front, 0])
+ cube([maxx-minx, totaldepth, height]);
+ }
+ for (x=[minx + sidemidx, maxx - sidemidx]) {
+ translate([x, 0, -screwabove])
+ ScrewHole();
+ }
+ for (yshift=[-1,1])
+ translate([0, yshift * frontbackslop, 0])
+ DoKnives();
+ AtSides() { BlockPegSlot(); BlockPegSlot(); }
+ }
+}
+
+module BlockPrint(){ ////toplevel
+ rotate([0,0,90])
+ Block();
+}
+
+module CoverTemplate(){
+ linear_extrude(height=coverthick)
+ polygon([[minx, 0],
+ [maxx, 0],
+ [maxx, coverlonglen+0.1],
+ [maxx - coverside, coverlonglen+0.1],
+ [minx, covershortlen+0.1]]);
+}
+
+module CoverSide(len){
+ translate([0, 0 ,0]) {
+ rotate([90,0,90])
+ linear_extrude(height=coverside)
+ polygon([[0, 0],
+ [0, totaldepth],
+ [covertopwing, totaldepth],
+ [covertopwingbase, coverside + coverthick],
+ [len - covertopwingbase, coverside + coverthick],
+ [len - covertopwing, totaldepth],
+ [len, totaldepth],
+ [len, 0]]);
+ cube([recessblockwidth, recessblockheight, totaldepth]);
+ }
+}
+
+module Peg(){
+ echo("peg angle slope (must be <1)",
+ (peghead-pegstem)/(pegheight-pegstemheight));
+ dx = pegsloph;
+ dy = pegslopv;
+ rotate([90,0,0]) {
+ linear_extrude(height=peglen-pegslopl) {
+ intersection(){
+ translate([-dx,-dy,0]) PegTemplate(0);
+ translate([-dx,+dy,0]) PegTemplate(0);
+ translate([+dx,+dy,0]) PegTemplate(0);
+ translate([+dx,-dy,0]) PegTemplate(0);
+ }
+ }
+ }
+}
+
+module CoverPegSlot(coverlen){
+ translate([recessblockwidth/2, 0, -1]){
+ linear_extrude(height= 1 + pegrecess + 0.5*peglen){
+ PegTemplate(0);
+ }
+ }
+}
+
+module HoleRow(){
+ imax = ceil(coverlonglen / holepitch);
+ echo("Holes Y count ", imax);
+ for (i=[0:imax]) {
+ translate([0, (i+0.5)*holepitch, -20])
+ cylinder(r=holesize/2, h=40, $fn=40);
+ }
+}
+
+module HolesScope(){
+ intersection_for (dx=[-1,+1]) {
+ intersection_for (dy=[-1,+1]) {
+ translate([dx * holeedge, dy * holeedge, -5])
+ scale([1,1,10])
+ CoverTemplate();
+ }
+ }
+}