X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=Makefile;h=3d1b5a512e0e96ae3a055ef3ffc0a468ec3f5ccc;hb=efabe7566f1d4f666168f47b5a6e2c0e63152b2b;hp=a2052616a669a0a304a5ffc21144aaf139197ff5;hpb=c4bef96ecaee63c8a679fb4b08ea2885e7be57e3;p=reprap-play.git diff --git a/Makefile b/Makefile index a205261..3d1b5a5 100644 --- a/Makefile +++ b/Makefile @@ -3,38 +3,59 @@ 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 --include .*.d +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 $*)) -%.stl: %.scad - openscad -d .$@.d -o $@ $< +-include .*.d -%.stl: %.ascad - 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 $@ -%.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 +%.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)