X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=Makefile;h=2c8684410814a3ebcd8e0d3bd6b770f406657a68;hp=881588b98529a9c85a47e44470ef609df2143776;hb=2acdcae963bf66d27a457f58343bc6b4fa6a8454;hpb=5fdc3fd6d60f4c345fda8cd777213eced3ecf666 diff --git a/Makefile b/Makefile index 881588b..2c86844 100644 --- a/Makefile +++ b/Makefile @@ -1,16 +1,99 @@ HRR=/home/reprap SLIC3R=$(HRR)/Slic3r/bin/slic3r +SKEINFORGE=python $(HRR)/reprappro-software.git/skeinforge/skeinforge_application/skeinforge_utilities/skeinforge_craft.py -CONFIG=slic3r-config.ini +CWD := $(shell pwd) +PLAY ?= $(CWD) -default: +CONFIG=$(PLAY)/slic3r-config.ini -%.stl: %.scad - openscad -o $@ $< +USING_AUTOS ?= filamentspool xeno-drivebay-bracket dungeonquest-cone anke-gps-bracket cable-hole-trunking-cover anglepoise-neck crossbar-computer-led-mount wardrobe-hook knifeblock pandemic-counter +AUTO_TOPLEVELS := $(foreach m,$(USING_AUTOS),$(shell $(PLAY)/toplevel-find $m)) -%.gcode: $(CONFIG) %.stl - $(SLIC3R) --load $^ --output $@ +AUTO_INCS = funcs.scad + +default: autoincs scads + +autoincs: $(AUTO_INCS) +scads: $(addsuffix .auto.scad, $(AUTO_TOPLEVELS)) +stls: $(addsuffix .auto.stl, $(AUTO_TOPLEVELS)) + +%.auto.scads: + $(MAKE) $(addsuffix .auto.scad, $(shell $(PLAY)/toplevel-find $*)) +%.auto.stls: + $(MAKE) $(addsuffix .auto.stl, $(shell $(PLAY)/toplevel-find $*)) + +-include .*.d + +%.stl: %.scad $(AUTO_INCS) + openscad -d .$@.d.tmp -o $*.tmp.stl $< + @rm -f $@ + @sed -e 's/\.tmp\.stl:/.stl:/' <.$@.d.tmp >.$@.d + @rm .$@.d.tmp + mv -f $*.tmp.stl $@ + +%.gcode: %.stl $(CONFIG) + $(SLIC3R) --load $(CONFIG) \ + --ignore-nonexistent-config --load $*.slic3r \ + --output $@.tmp $< + @mv -f $@.tmp $@ + +%.gcode-sd: %.gcode + mount /media/sd + cp $^ /media/sd/JOB.G + sleep 0.5 + umount /media/sd + +%: %.cpp + cpp -nostdinc -P <$< >$@.tmp && mv -f $@.tmp $@ + +funcs.scad: + +#%.gcode: %.stl +# $(SKEINFORGE) $< %.gcode: manual-gcode-generator %.m-g - ./$^ >$@.new && mv -f $@.new $@ + $(PLAY)/$^ >$@.tmp && mv -f $@.tmp $@ + +dovecliptest.stl: doveclip.scad $(AUTO_INCS) + +KNIFEBLOCK_KNIVES= 0 1 2 +KNIFEBLOCK_TEMPLATES= bl hl +KNIFEBLOCK_TEMPLATE_FILES=\ + $(foreach k,$(KNIFEBLOCK_KNIVES), \ + $(foreach t,$(KNIFEBLOCK_TEMPLATES), \ + knifeblock-knives-t$k$t.dxf)) + +knifeblock-knives-templates knifeblock.stl: $(KNIFEBLOCK_TEMPLATE_FILES) + +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 pandemic-counter.stl: $(PANDEMICCOUNTER_DXFS) + +pandemic-counter-l%.eps: pandemic-counter-letters.fig + fig2dev -D +$(notdir $*) -L eps <$< >$@.tmp + @mv -f $@.tmp $@ + +%.dxf: %.eps + pstoedit -dt -f "dxf: -polyaslines -mm" $< $@ + +%: %.pl + ./$< >$@.tmp && mv -f $@.tmp $@ + +%.auto.scad: $(PLAY)/toplevel-make Makefile $(PLAY)/toplevel-find + @echo ' write $@' + $< $@ >$@.tmp + @mv -f $@.tmp $@ + +.PRECIOUS: %.stl %.gcode + +clean: + rm -f *~ *.stl *.auto.scad *.gcode .*.d $(AUTO_INCS)