Merge branch 'master' of ssh://git.gag.com/scm/git/hw/teleterra
[hw/teleterra] / Makefile
index 05b807d40d0bbb6d6c6a29bb494e846b636dbfa4..4f855c110aa8208939ab27e7d62df5f9bd9c5841 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,16 +1,26 @@
+AM=../altusmetrum
+SCHEME=$(AM)/scheme
+
 # intentionally want to rebuild drc and bom on every invocation
-all:   drc bom
+all:   drc partslist partslist.csv pcb
+
+drc:   teleterra.sch Makefile
+       -gnetlist -g drc2 teleterra.sch -o teleterra.drc
 
-drc:   telemetrum.sch
-       -gnetlist -g drc2 telemetrum.sch -o telemetrum.drc
+partslist:     teleterra.sch Makefile
+       gnetlist -g bom -o teleterra.unsorted teleterra.sch
+       head -n1 teleterra.unsorted > partslist
+       tail -n+2 teleterra.unsorted | sort >> partslist
+       rm -f teleterra.unsorted
 
-bom:   telemetrum.sch
-       gnetlist -g bom -o telemetrum.unsorted telemetrum.sch
-       head -n1 telemetrum.unsorted > telemetrum.bom
-       tail -n+2 telemetrum.unsorted | sort >> telemetrum.bom
-       rm -f telemetrum.unsorted
+partslist.csv: teleterra.sch Makefile
+       gnetlist -L $(SCHEME) -g partslistgag \
+               -o teleterra.unsorted teleterra.sch
+       head -n1 teleterra.unsorted > partslist.csv
+       tail -n+2 teleterra.unsorted | sort -t \, -k 8 >> partslist.csv
+       rm -f teleterra.unsorted
 
-pcb:   telemetrum.sch project
+pcb:   teleterra.sch project Makefile
        gsch2pcb project
 
 # note that 'gschlas -e foo.sch' will embed all symbols in the schematic, this
@@ -28,11 +38,36 @@ pcb:        telemetrum.sch project
 push:  
        git push --mirror
 
-zip:   telemetrum.back.gbr telemetrum.backmask.gbr telemetrum.fab.gbr telemetrum.front.gbr telemetrum.frontmask.gbr telemetrum.frontpaste.gbr telemetrum.frontsilk.gbr telemetrum.group2.gbr telemetrum.group3.gbr telemetrum.plated-drill.cnc
-       zip telemetrum.zip *.gbr *.cnc
+teleterra.xy:  teleterra.pcb
+       pcb -x bom teleterra.pcb
+
+teleterra.bottom.gbr:  teleterra.pcb
+       pcb -x gerber teleterra.pcb
+
+zip:   teleterra.bottom.gbr teleterra.bottommask.gbr teleterra.fab.gbr teleterra.top.gbr teleterra.topmask.gbr teleterra.toppaste.gbr teleterra.topsilk.gbr teleterra.plated-drill.cnc teleterra.xy  Makefile # teleterra.xls
+       zip teleterra.zip teleterra.*.gbr teleterra.*.cnc teleterra.xy # teleterra.xls
+
+oshpark: teleterra.bottom.gbr teleterra.bottommask.gbr teleterra.top.gbr teleterra.topmask.gbr teleterra.topsilk.gbr teleterra.plated-drill.cnc
+       mv teleterra.bottom.gbr bottom\ layer.ger
+       mv teleterra.bottommask.gbr bottom\ solder\ mask.ger
+       mv teleterra.bottomsilk.gbr bottom\ silk\ screen.ger
+       mv teleterra.outline.gbr board\ outline.ger
+       mv teleterra.top.gbr top\ layer.ger
+       mv teleterra.topmask.gbr top\ solder\ mask.ger
+       mv teleterra.topsilk.gbr top\ silk\ screen.ger
+       mv teleterra.plated-drill.cnc drills.xln
+       zip teleterra-oshpark.zip *.ger *.xln
+
+stencil:       teleterra.bottom.gbr teleterra.toppaste.gbr teleterra.outline.gbr
+       zip teleterra-stencil.zip teleterra.toppaste.gbr teleterra.outline.gbr
 
 clean:
-       rm -f *.bom *.drc *.log *~ telemetrum.ps *.gbr *.cnc *bak* *- *.zip 
-       rm -f *.net *.xy *.cmd *.png
-       rm -f *.partslist *.new.pcb *.unsorted
+       rm -f *.bom *.drc *.log *~ teleterra.ps *.gbr *.cnc *bak* *- *.zip 
+       rm -f *.net *.xy *.cmd *.png partslist partslist.csv *.ger *.xln
+       rm -f *.partslist *.new.pcb *.unsorted teleterra.xls muffin-5267.pdf
+
+muffins: partslist.csv $(AM)/glabels/muffin-short-5267.glabels
+       glabels-3-batch $(AM)/glabels/muffin-short-5267.glabels \
+               -i partslist.csv -o muffin-5267.ps >/dev/null && \
+               ps2pdf muffin-5267.ps && rm muffin-5267.ps