2011-02-15 07:06:26 +02:00
|
|
|
#!/bin/sh
|
|
|
|
PATH=$PATH:/home/qi/cae-tools/cameo
|
2011-09-01 09:38:27 +03:00
|
|
|
PATH=$PATH:/home/qi/cae-tools/gp2rml
|
2011-02-15 07:06:26 +02:00
|
|
|
|
|
|
|
#
|
|
|
|
# Parameters:
|
|
|
|
#
|
|
|
|
# NAME KiCad project name, required
|
|
|
|
# X0, Y0 lower left corner of raw board, default: 0mm 0mm
|
|
|
|
# X, Y position in array, default: 0 0
|
|
|
|
# XN, YN number of boards in X/Y direction, default: 1 1
|
2015-10-05 00:40:30 +03:00
|
|
|
# Z0 tool height when in contact with the surface
|
2011-02-15 07:06:26 +02:00
|
|
|
# ROT board rotation, default: 0 degrees
|
|
|
|
# DRILL drill diameter range, default: 13mil,14mil
|
|
|
|
# MILL_IN diameter of mill for work inside the board, default: 35mil
|
|
|
|
# MILL_OUT diameter of mill for board edge, default: 35mil
|
2011-08-31 20:53:56 +03:00
|
|
|
# BOARD_Z board tickness, default: 0.8 mm
|
2011-09-01 03:31:42 +03:00
|
|
|
# ANY set to "any" to use all remaining paths for milling,
|
|
|
|
# irrespective of tool size. Default: unset / empty string.
|
2011-09-01 18:00:58 +03:00
|
|
|
# CLEARANCE tool clearance above PCB surface, default: 2mm
|
2011-02-15 07:06:26 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
while [ "$1" ]; do
|
|
|
|
eval "$1"
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
if ! [ "$NAME" ]; then
|
|
|
|
echo "NAME is required" 1>&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
: ${X0:=0} ${Y0:=0}
|
|
|
|
: ${X:=0} ${Y:=0}
|
|
|
|
: ${XN:=1} ${YN:=1}
|
2015-10-05 00:40:30 +03:00
|
|
|
: ${Z0:=-57.4}
|
2011-02-15 07:06:26 +02:00
|
|
|
: ${DRILL:="13mil 14mil"}
|
|
|
|
: ${MILL_IN:=35mil}
|
|
|
|
: ${MILL_OUT:=35mil}
|
2011-08-31 20:53:56 +03:00
|
|
|
: ${BOARD_Z:=0.8mm}
|
2011-09-01 18:00:58 +03:00
|
|
|
: ${CLEARANCE:=2mm}
|
2011-02-15 07:06:26 +02:00
|
|
|
|
|
|
|
rot=
|
|
|
|
if [ "$ROT" ]; then
|
|
|
|
rot="rotate $ROT"
|
|
|
|
fi
|
|
|
|
|
2015-01-28 18:59:59 +02:00
|
|
|
edges=$NAME.gp
|
|
|
|
[ -r "$edges" ] || edges=
|
2013-08-07 01:15:48 +03:00
|
|
|
for n in PCB_Edges.gbr Edge_Cuts.gbr Edge_Cuts.pho; do
|
|
|
|
if [ -r "../$NAME-$n" ]; then
|
|
|
|
edges=../$NAME-$n
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if [ ! "$edges" ]; then
|
|
|
|
echo "no edges file found" 1>&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2011-02-15 07:06:26 +02:00
|
|
|
write=write
|
|
|
|
yi=0
|
|
|
|
while [ $yi -lt $YN ]; do
|
|
|
|
xi=0
|
|
|
|
while [ $xi -lt $XN ]; do
|
|
|
|
|
2011-09-01 03:32:10 +03:00
|
|
|
cameo <<EOF || exit
|
2011-02-15 07:06:26 +02:00
|
|
|
mm
|
|
|
|
|
2015-01-28 18:59:59 +02:00
|
|
|
`if [ "$edges" != "${edges%.gp}" ]; then echo gnuplot 35mil $edges;
|
|
|
|
else echo gerber 35mil $edges; fi`
|
2011-02-15 07:06:26 +02:00
|
|
|
$rot
|
|
|
|
align 1 $X0 $Y0 # align relative to board corner
|
|
|
|
translate 4mm 4mm # move to PCB zone assigned to project
|
|
|
|
array +3mm +3mm `expr $X + $xi` `expr $Y + $yi`
|
2015-10-05 00:40:30 +03:00
|
|
|
z 0 ${Z0}mm # board surface (tool extended)
|
2011-08-31 20:53:56 +03:00
|
|
|
z -$BOARD_Z # board thickness
|
2011-02-15 07:06:26 +02:00
|
|
|
z -0.5mm # tool extra depth
|
|
|
|
clear
|
|
|
|
|
2014-04-27 16:45:54 +03:00
|
|
|
`[ -r ../$NAME.drl ] && echo excellon ../$NAME.drl`
|
2012-08-24 05:01:49 +03:00
|
|
|
`[ -r ../$NAME-NPTH.drl ] && echo excellon ../$NAME-NPTH.drl`
|
2011-02-15 07:06:26 +02:00
|
|
|
drill $DRILL
|
|
|
|
optimize
|
|
|
|
$write drill.gp
|
|
|
|
|
|
|
|
remainder
|
2011-09-01 03:31:42 +03:00
|
|
|
mill $ANY $MILL_IN 0.01mm
|
2011-02-15 07:06:26 +02:00
|
|
|
$write mill.gp
|
|
|
|
|
|
|
|
remainder
|
|
|
|
empty
|
|
|
|
|
2015-01-28 18:59:59 +02:00
|
|
|
`if [ "$edges" != "${edges%.gp}" ]; then echo gnuplot $MILL_OUT $edges;
|
|
|
|
else echo gerber $MILL_OUT $edges; fi`
|
2011-02-15 07:06:26 +02:00
|
|
|
offset
|
|
|
|
append mill.gp
|
|
|
|
EOF
|
|
|
|
|
|
|
|
write=append
|
|
|
|
xi=`expr $xi + 1`
|
|
|
|
done
|
|
|
|
yi=`expr $yi + 1`
|
|
|
|
done
|
|
|
|
|
2011-09-01 18:02:37 +03:00
|
|
|
gp2rml $CLEARANCE 0.5 0.5 mill.gp >mill.rml || exit
|
|
|
|
gp2rml $CLEARANCE 0.1 0.5 drill.gp >drill.rml || exit
|
2011-02-15 07:06:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
cat <<EOF >Makefile.mkmk
|
|
|
|
SPOOL=/home/moko/svn.openmoko.org/developers/werner/cncmap/spool/spool
|
|
|
|
CNGT=/home/qi/cae-tools/cngt/cngt
|
|
|
|
|
|
|
|
.PHONY: mill drill cng plot dplot
|
|
|
|
|
|
|
|
mill:
|
|
|
|
PORT=/dev/ttyUSB0 \$(SPOOL) mill.rml
|
|
|
|
|
|
|
|
drill:
|
|
|
|
PORT=/dev/ttyUSB0 \$(SPOOL) drill.rml
|
|
|
|
|
|
|
|
cng:
|
2015-10-05 00:40:30 +03:00
|
|
|
\$(CNGT) $Z0 20 mill.gp
|
2011-02-15 07:06:26 +02:00
|
|
|
|
|
|
|
plot:
|
2012-12-28 00:52:16 +02:00
|
|
|
echo 'set size ratio -1; \
|
2012-11-22 04:17:23 +02:00
|
|
|
plot "drill.gp" with points, "mill.gp" with lines' | \\
|
2011-02-15 07:06:26 +02:00
|
|
|
gnuplot -persist
|
|
|
|
|
|
|
|
dplot:
|
2012-12-28 00:52:16 +02:00
|
|
|
echo 'set size ratio -1; \
|
2012-11-22 04:17:23 +02:00
|
|
|
plot "< sed /^\$\$/d drill.gp" with linespoints' | \\
|
2011-02-15 07:06:26 +02:00
|
|
|
gnuplot -persist
|
|
|
|
|
|
|
|
clean::
|
|
|
|
rm -f mill.gp mill.rml drill.gp drill.rml
|
|
|
|
EOF
|