2022-06-22 09:12:23 +02:00
# project file name (use for schematic and board layout)
NAME ?= template
# path to qeda
QEDA := qeda
# read project version
VERSION := $( shell cat version)
# current date for stamping output
DATE = $( shell date +%Y-%m-%d)
2022-07-04 10:17:51 +02:00
# revision based on number of changes on schematic or board layout
REVISION := $( shell git log --pretty= oneline " ${ NAME } .kicad_sch " " ${ NAME } .kicad_pcb " | wc -l)
2022-06-22 09:12:23 +02:00
# generate file with version information
VERSIONED_EXT = kicad_sch kicad_pcb kicad_pro json
d e f i n e v e r s i o n _ r u l e
%.versioned.$1 : %.$1
cp $$ < $$ @
sed --in-place 's/\$$$$version\$$$$/${VERSION}/g' $$ @
sed --in-place 's/\$$$$date\$$$$/${DATE}/g' $$ @
sed --in-place 's/\$$$$revision\$$$$/${REVISION}/g' $$ @
e n d e f
$( foreach EXT ,$ ( VERSIONED_EXT ) ,$ ( eval $ ( call version_rule ,$ ( EXT ) ) ) )
2022-08-10 14:45:31 +02:00
FABRICATION_DIR := fabrication
IBOM := ${ FABRICATION_DIR } /ibom.html
all : ${NAME }.sch .pdf ${NAME }.brd -top .png ${NAME }.brd -bot .png ${NAME }.bom .csv fab
fab : ${FABRICATION_DIR } ${IBOM }
2022-06-22 09:12:23 +02:00
# generate fabrication files (gerbers/drill/BoM/PnP)
2022-08-10 14:45:31 +02:00
${FABRICATION_DIR} : ${NAME }.versioned .kicad_sch ${NAME }.versioned .kicad_pcb
kikit fab jlcpcb --drc --assembly --schematic $^ $@
# generate interactive BoM
${IBOM} : ${NAME }.versioned .kicad_pcb
$( IBOMGEN) --no-browser --dest-dir ` dirname $@ ` --name-format ` basename $@ ".html" ` --show-fields "Value" $< & >/dev/null
2022-06-22 09:12:23 +02:00
# generate symbols and footprints from parts
lib :
$( QEDA) generate qeda
# generate printable version (PDF) of schematic
%.sch.pdf : %.versioned .kicad_sch %.versioned .kicad_pro
eeschema_do export $< .
mv $* .versioned.pdf $@
# generate render from layout (top side)
%.brd-top.png : %.versioned .kicad_pcb
pcbdraw --silent $< --dpi 600 $@
# generate render from layout (bottom side)
%.brd-bot.png : %.versioned .kicad_pcb
pcbdraw --silent $< --dpi 600 --back $@
# export Bill of Material (as CSV)
%.bom.csv : %.versioned .kicad_sch %.versioned .kicad_pro
eeschema_do bom_xml $< .
kibom $* .versioned.xml $@
# generate panel
PANEL_DIR := panel
panel : panel .kicad_pcb
panel.kicad_pcb : ${NAME }.versioned .kicad_pcb ${NAME }.versioned .kicad_pro ${NAME }.versioned .kicad_sch ${NAME }.versioned .json
kikit panelize -p ${ NAME } .versioned.json ${ NAME } .versioned.kicad_pcb $@
sed --in-place 's/\"missing_courtyard\": \"warning\"/\"missing_courtyard\": \"ignore\"/g' $( patsubst %.kicad_pcb,%.kicad_pro,$@ ) # the mouse bites don't have a courtyard
kikit fab jlcpcb --drc --assembly --missingError --schematic ${ NAME } .versioned.kicad_sch $@ ${ PANEL_DIR }
2022-07-13 11:10:21 +02:00
pcbdraw --silent $@ --dpi 600 panel.brd-top.png
pcbdraw --silent $@ --dpi 600 --back panel.brd-bot.png
2022-06-22 09:12:23 +02:00
clean :
rm -f $( foreach EXT,$( VERSIONED_EXT) ,${ NAME } .versioned.$( EXT) )
rm -f ${ NAME } .sch.pdf ${ NAME } .brd-top.png ${ NAME } .brd-bot.png ${ NAME } .versioned.xml ${ NAME } .bom.csv
rm -f ${ NAME } .versioned.kicad_prl ${ NAME } .versioned.kicad_pro-bak ${ NAME } .versioned.xml ${ NAME } .versioned.csv
2022-08-10 14:45:31 +02:00
rm -f ${ IBOM }
2022-06-22 09:12:23 +02:00
rm -rf ${ FABRICATION_DIR }
rm -f panel.kicad_pcb panel.kicad_pro
rm -rf ${ PANEL_DIR }