working on v0.3
[hw/teleterra] / Makefile
index 05b807d40d0bbb6d6c6a29bb494e846b636dbfa4..8faefb972eab1b4a52ad5dbc20230bafbbdad768 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,16 +1,29 @@
 # intentionally want to rebuild drc and bom on every invocation
-all:   drc bom
+all:   hw
 
-drc:   telemetrum.sch
-       -gnetlist -g drc2 telemetrum.sch -o telemetrum.drc
+hw:    drc partslist partslist.csv
 
-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
+CC=            sdcc
+CFLAGS=                -mpic14 -p16f886
+LDFLAGS=       
 
-pcb:   telemetrum.sch project
+drc:   teleterra.sch
+       -gnetlist -g drc2 teleterra.sch -o teleterra.drc
+
+partslist:     teleterra.sch
+       gnetlist -g bom -o teleterra.unsorted teleterra.sch
+       head -n1 teleterra.unsorted > partslist
+       tail -n+2 teleterra.unsorted | sort >> partslist
+       rm -f teleterra.unsorted
+
+partslist.csv: teleterra.sch Makefile
+       gnetlist -m scheme/gnet-partslistgag.scm -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:   teleterra.sch project
        gsch2pcb project
 
 # note that 'gschlas -e foo.sch' will embed all symbols in the schematic, this
@@ -28,11 +41,18 @@ 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
+       zip teleterra.zip *.gbr *.cnc
 
 clean:
-       rm -f *.bom *.drc *.log *~ telemetrum.ps *.gbr *.cnc *bak* *- *.zip 
-       rm -f *.net *.xy *.cmd *.png
+       rm -f *.bom *.drc *.log *~ teleterra.ps *.gbr *.cnc *bak* *- *.zip 
+       rm -f *.net *.xy *.cmd *.png partslist partslist.csv
        rm -f *.partslist *.new.pcb *.unsorted
+       rm -f *.hex *.cod *.lst *.ps *.o *.asm