move to use of shared symbol library
[hw/teleterra] / Makefile
index 9036f5444dbdf1aec399f8971070d0950fb2f44f..ffd17a74ce0b31f612b5132a1c3b485b43a0b1df 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,12 +1,13 @@
-# intentionally want to rebuild drc and bom on every invocation
-all:   hw sw
+PROJECT=teleterra
 
-hw:    drc partslist 
+# intentionally want to rebuild drc and bom on every invocation
+all:   hw
 
-sw:    teleterra.hex
+hw:    drc partslist partslist.csv partslist.dk partslist.mouser
 
-teleterra.hex: teleterra.asm
-       gpasm teleterra.asm
+CC=            sdcc
+CFLAGS=                -mpic14 -p16f886
+LDFLAGS=       
 
 drc:   teleterra.sch
        -gnetlist -g drc2 teleterra.sch -o teleterra.drc
@@ -17,6 +18,19 @@ partslist:   teleterra.sch
        tail -n+2 teleterra.unsorted | sort >> partslist
        rm -f teleterra.unsorted
 
+partslist.csv: teleterra.sch Makefile
+       gnetlist -L ../altusmetrum/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
+
+partslist.dk:  $(PROJECT).sch Makefile 
+       gnetlist -L ../altusmetrum/scheme -g partslist-bom -Ovendor=digikey -o $@ $(PROJECT).sch
+
+partslist.mouser:      $(PROJECT).sch Makefile
+       gnetlist -L ../altusmetrum/scheme -g partslist-bom -Ovendor=mouser -o $@ $(PROJECT).sch
+
 pcb:   teleterra.sch project
        gsch2pcb project
 
@@ -35,12 +49,33 @@ pcb:        teleterra.sch project
 push:  
        git push --mirror
 
-zip:   teleterra.back.gbr teleterra.backmask.gbr teleterra.fab.gbr teleterra.front.gbr teleterra.frontmask.gbr teleterra.frontpaste.gbr teleterra.frontsilk.gbr teleterra.group2.gbr teleterra.group3.gbr teleterra.plated-drill.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
        zip teleterra.zip *.gbr *.cnc
 
+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 *~ teleterra.ps *.gbr *.cnc *bak* *- *.zip 
-       rm -f *.net *.xy *.cmd *.png partslist
+       rm -f *.net *.xy *.cmd *.png partslist partslist.csv
        rm -f *.partslist *.new.pcb *.unsorted
-       rm -f *.hex *.cod *.lst
+       rm -f *.hex *.cod *.lst *.ps *.o *.asm
+       rm -f *.ger *.xln *.dk *.mouser