X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=Makefile;h=bd47f9cb668467df11f6c0d95ad627dc6ae4fc84;hp=bee41a154cebdde6d634ce6a23855f4f541eae09;hb=4982e66d15e9dcc3aec326dfe480cdec31aaaf91;hpb=41a5ac4f7227cd178a5b14ee1f78ebbaf3a2e63a diff --git a/Makefile b/Makefile index bee41a1..bd47f9c 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,25 @@ +# reprap-objects Makefile +# +# Build scripts for various 3D designs +# Copyright 2012-2016 Ian Jackson +# +# This work is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This work is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this work. If not, see . + HRR=/home/reprap SLIC3R=$(HRR)/Slic3r/bin/slic3r +M4=m4 SKEINFORGE=python $(HRR)/reprappro-software.git/skeinforge/skeinforge_application/skeinforge_utilities/skeinforge_craft.py CWD := $(shell pwd) @@ -8,18 +27,24 @@ PLAY ?= $(CWD) CONFIG=$(PLAY)/slic3r-config.ini -USING_AUTOS ?= filamentspool xeno-drivebay-bracket dungeonquest-cone anke-gps-bracket cable-hole-trunking-cover anglepoise-neck crossbar-computer-led-mount wardrobe-hook +FILAMENTSPOOL_AUTOS = filamentspool filamentspool-lt filamentspool-sm +FILAMENTSPOOL_AUTOS += filamentspool-storarm3 + +USING_AUTOS ?= $(FILAMENTSPOOL_AUTOS) xeno-drivebay-bracket dungeonquest-cone anke-gps-bracket cable-hole-trunking-cover anglepoise-neck crossbar-computer-led-mount wardrobe-hook knifeblock pandemic-counter pattress-boxes-3-cover bike-lipo-box earring-stand bike-stalk-led-mount sewing-table + AUTO_TOPLEVELS := $(foreach m,$(USING_AUTOS),$(shell $(PLAY)/toplevel-find $m)) -AUTO_INCS = funcs.scad +AUTO_INCS = funcs.scad utils.scad sealing-box.scad sewing-table.scad default: autoincs scads +$(shell set -xe; $(PLAY)/commitid.scad.pl >commitid.scad.tmp; cmp commitid.scad.tmp commitid.scad || mv -f commitid.scad.tmp commitid.scad ) + autoincs: $(AUTO_INCS) scads: $(addsuffix .auto.scad, $(AUTO_TOPLEVELS)) stls: $(addsuffix .auto.stl, $(AUTO_TOPLEVELS)) -%.auto.scads: +%.auto.scads: %.scad $(MAKE) $(addsuffix .auto.scad, $(shell $(PLAY)/toplevel-find $*)) %.auto.stls: $(MAKE) $(addsuffix .auto.stl, $(shell $(PLAY)/toplevel-find $*)) @@ -33,14 +58,19 @@ stls: $(addsuffix .auto.stl, $(AUTO_TOPLEVELS)) @rm .$@.d.tmp mv -f $*.tmp.stl $@ +AUTOBASE=$(shell echo $(1) | perl -pe 's/,\w+\.auto$$//') + %.gcode: %.stl $(CONFIG) $(SLIC3R) --load $(CONFIG) \ - --ignore-nonexistent-config --load $*.slic3r \ + --ignore-nonexistent-config \ + --load $(call AUTOBASE,$*).slic3r \ + --load $*.slic3r \ --output $@.tmp $< @mv -f $@.tmp $@ %.gcode-sd: %.gcode mount /media/sd + rm -f /media/sd/JOB.* /media/sd/job.* cp $^ /media/sd/JOB.G sleep 0.5 umount /media/sd @@ -48,6 +78,8 @@ stls: $(addsuffix .auto.stl, $(AUTO_TOPLEVELS)) %: %.cpp cpp -nostdinc -P <$< >$@.tmp && mv -f $@.tmp $@ +funcs.scad: + #%.gcode: %.stl # $(SKEINFORGE) $< @@ -65,20 +97,90 @@ KNIFEBLOCK_TEMPLATE_FILES=\ knifeblock-knives-templates knifeblock.stl: $(KNIFEBLOCK_TEMPLATE_FILES) +.PRECIOUS: knifeblock-knives-t%.dxf knifeblock-knives-t%.dxf: knifeblock-knives-filter knifeblock-knives-trace.fig ./$< $(notdir $*) <$(filter %.fig, $^) >$@.tmp.fig fig2dev -D -30 -L eps <$@.tmp.fig >$@.tmp.eps pstoedit -dt -f "dxf: -polyaslines -mm" $@.tmp.eps $@ +PANDEMICCOUNTER_LETTERS=30 31 32 33 34 35 +PANDEMICCOUNTER_DXFS=$(foreach l,$(PANDEMICCOUNTER_LETTERS), \ + pandemic-counter-l$l.dxf) + +pandemic-counter-letters: $(PANDEMICCOUNTER_DXFS) +pandemic-counter%.stl: $(PANDEMICCOUNTER_DXFS) + +.PRECIOUS: pandemic-counter-l%.eps +pandemic-counter-l%.eps: pandemic-counter-letters.fig + fig2dev -D +$(notdir $*) -L eps <$< >$@.tmp + @mv -f $@.tmp $@ + +PANDEMICQUARANTINES_NUMBERS=1 2 +PANDEMICQUARANTINES_DXFS=$(foreach l,$(PANDEMICQUARANTINES_NUMBERS), \ + pandemic-quarantine-l$l.dxf) + +pandemic-quarantine-numbers: $(PANDEMICQUARANTINES_DXFS) +pandemic-quarantine%.stl: $(PANDEMICQUARANTINES_DXFS) + +.PRECIOUS: pandemic-quarantine-l%.eps +pandemic-quarantine-l%.eps: pandemic-quarantine-numbers.fig + fig2dev -D +$(notdir $*) -L eps <$< >$@.tmp + @mv -f $@.tmp $@ + +FILAMENTSPOOL_NUMBERS=$(shell seq 300 100 1500) +filamentspool-number-n%.eps: filamentspool-number.eps.pl + ./$< $* >$@.tmp && mv -f $@.tmp $@ + +FILAMENTSPOOL_DXFS=$(foreach n,$(FILAMENTSPOOL_NUMBERS), \ + filamentspool-number-n$n.dxf) + +$(addsuffix .auto.stl, $(foreach f,$(FILAMENTSPOOL_AUTOS),$(shell \ + $(PLAY)/toplevel-find $(PLAY)/$f))): $(FILAMENTSPOOL_DXFS) + +filamentspool-numbers filamentspool.stl: $(FILAMENTSPOOL_DXFS) + +SCREWRECESSTEST_SIZES= 2 3 4 5 6 +SCREWRECESSTEST_DXFS=$(foreach s,$(SCREWRECESSTEST_SIZES), \ + screw-recess-test-number-s$s.dxf) + +screw-recess-test-number-s%.fig: screw-recess-test-number.fig.pl + ./$< $* >$@.tmp && mv -f $@.tmp $@ + +screw-recess-test-number-s%.eps: screw-recess-test-number-s%.fig + fig2dev -L eps <$< >$@.tmp + @mv -f $@.tmp $@ + +screw-recess-test-numbers screw-recess-test.stl: $(SCREWRECESSTEST_DXFS) + +question-question.eps: question-question.fig + fig2dev -L eps <$< >$@.tmp + @mv -f $@.tmp $@ + +question-token.stl: question-question.dxf + +lemon-stand.stl: lemon-stand.scad + +.PRECIOUS: $(SCREWRECESSTEST_DXFS) $(SCREWRECESSTEST_DXFS) \ + $(foreach s,$(SCREWRECESSTEST_SIZES), \ + screw-recess-test-number-s$s.fig \ + screw-recess-test-number-s$s.eps) + +%.dxf: %.eps + pstoedit -dt -f "dxf: -polyaslines -mm" $< $@ + %: %.pl ./$< >$@.tmp && mv -f $@.tmp $@ +%: %.m4 + $(M4) -P >$@.tmp $< && mv -f $@.tmp $@ + +.PRECIOUS: %.auto.scad %.auto.scad: $(PLAY)/toplevel-make Makefile $(PLAY)/toplevel-find @echo ' write $@' $< $@ >$@.tmp @mv -f $@.tmp $@ -.PRECIOUS: %.stl %.gcode +.PRECIOUS: %.stl %.gcode %.eps %.dxf clean: rm -f *~ *.stl *.auto.scad *.gcode .*.d $(AUTO_INCS)