X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=Makefile;h=ce63b8dc9dfc9a648a88c45fb098155500ccefed;hb=779a304ce2ba43b18d2467807c4325b52ab4aa90;hp=a2052616a669a0a304a5ffc21144aaf139197ff5;hpb=c4bef96ecaee63c8a679fb4b08ea2885e7be57e3;p=reprap-play.git diff --git a/Makefile b/Makefile index a205261..ce63b8d 100644 --- a/Makefile +++ b/Makefile @@ -3,38 +3,79 @@ 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) -AUTO_TOPLEVELS := $(foreach m, filamentspool, $(shell ./toplevel-find $m)) +CONFIG=$(PLAY)/slic3r-config.ini -scads: $(addsuffix .ascad, $(AUTO_TOPLEVELS)) -stls: $(addsuffix .stl, $(AUTO_TOPLEVELS)) +USING_AUTOS ?= filamentspool xeno-drivebay-bracket dungeonquest-cone anke-gps-bracket cable-hole-trunking-cover anglepoise-neck crossbar-computer-led-mount wardrobe-hook +AUTO_TOPLEVELS := $(foreach m,$(USING_AUTOS),$(shell $(PLAY)/toplevel-find $m)) -default: +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 - openscad -d .$@.d -o $@ $< +%.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 $@ -%.stl: %.ascad - openscad -d .$@.d -o $@ $< +%.gcode-sd: %.gcode + mount /media/sd + cp $^ /media/sd/JOB.G + sleep 0.5 + umount /media/sd -%.gcode: $(CONFIG) %.stl - $(SLIC3R) --load $^ --output $@ +%: %.cpp + cpp -nostdinc -P <$< >$@.tmp && mv -f $@.tmp $@ #%.gcode: %.stl # $(SKEINFORGE) $< %.gcode: manual-gcode-generator %.m-g - ./$^ >$@.tmp && mv -f $@.tmp $@ + $(PLAY)/$^ >$@.tmp && mv -f $@.tmp $@ -dovecliptest.stl: doveclip.scad +dovecliptest.stl: doveclip.scad $(AUTO_INCS) -%.ascad: toplevel-make Makefile toplevel-find +KNIFEBLOCK_LAYERS=1 2 3 4 5 6 +KNIFEBLOCK_LAYER_FILES=$(foreach l,$(KNIFEBLOCK_LAYERS), \ + knifeblock-knives-l$l.dxf) + +knifeblock-knives-layers: $(KNIFEBLOCK_LAYER_FILES) + +knifeblock-knives-l%.dxf: knifeblock-knives-filter knifeblock-knives-trace.fig + ./$< $* <$(filter %.fig, $^) >$@.tmp.fig + fig2dev -L eps <$@.tmp.fig >$@.tmp.eps + pstoedit -dt -f "dxf: -polyaslines -mm" $@.tmp.eps $@ + +%: %.pl + ./$< >$@.tmp && mv -f $@.tmp $@ + +%.auto.scad: $(PLAY)/toplevel-make Makefile $(PLAY)/toplevel-find @echo ' write $@' - ./$< $@ >$@.tmp + $< $@ >$@.tmp @mv -f $@.tmp $@ +.PRECIOUS: %.stl %.gcode + clean: - rm -f *~ *.stl *,*.scad *.gcode .*.d + rm -f *~ *.stl *.auto.scad *.gcode .*.d $(AUTO_INCS)