7 LAYOUTOPTS_ALL= -ep=*Cm
8 LAYOUTOPTS= -E=*$(E_TRACK) $(LAYOUTOPTS_ALL)
9 LAYOUTOPTS_PHYS= -S1.0 $(LAYOUTOPTS) '-e*A'
10 XLAYOUTOPTS_LAYER= -e'=5AN' -E'*~=5rsm' -e'p~=5r' -e'*~=9C' -e'*=*l'
12 LAYOUTOPTS_SEGS= '-e*=*rm'
15 LAYERS_PS= $(addsuffix .ps, $(LAYERS_LS))
16 LAYERS_L= $(addprefix ours-l, $(LAYERS_PS))
17 LAYERS_E= $(addprefix ours-e, $(LAYERS_PS))
18 LAYERS= $(LAYERS_L) $(LAYERS_E)
20 LPAGES= $(foreach x, 0 1 2 3 4 5 6, $(foreach y, 1 2 3 4 5, ours-p0-$xx$y.ps))
22 CPROGS= subseg2display compose-segenco
24 default: $(CPROGS) for-test-ui
25 all: default lpages layers extras
26 for-test-ui: ours.graph.c ours.redactgraph ours.raw.neato.ps \
27 ours.redacted.neato.ps ours.layout-data.o \
28 ours.dgram-bot.segcmap subseg2display ui-plan-bot.ppm
32 extras: dualjn-a.ps parts.ps
35 include segencolayers.m
40 REDACT= consistency movfeatsplitedges \
41 consistency movfeatrmstubs \
42 consistency movfeatsplitnodes \
43 consistency trivpairnodes \
44 consistency trivnullnodes
46 subseg2display: subseg2display.o
47 $(LINK) $(NETPBM) -lpub -lm
49 compose-segenco: compose-segenco.o
55 %.raw.neato: %.redactgraph
56 ./$< consistency printforneato $o
58 %.redacted.neato: %.redactgraph
59 ./$< $(REDACT) consistency printforneato $o
61 %.redacted.forsafety: %.redactgraph
62 ./$< $(REDACT) consistency printforforsafety $o
64 %.layout-data.c: data2safety %.wiring %.redacted.forsafety
67 %.redactgraph: %.graph.o redactgraph.o
70 %.d4: %.m4 $(M4INCS) Makefile
74 ./layout <$< $(LAYOUTOPTS) '-E*l' $o
77 ./layout <$< $(LAYOUTOPTS) '-e*C' '-ep=rm' $o
80 ./layout -S1.0 <$< $(LAYOUTOPTS) '-e*A' '-ep=rm' $o
82 %.segcmapreq: %.run-layout
83 ./$< $(LAYOUTOPTS_SEGS) -GR $o
85 %.segcmap: %.segcmapreq segcmapassign segcmap.h
86 ./segcmapassign <$< $o
88 %.dgram.m: %.dgram-list make-dgram-make
89 ./make-dgram-make <$< $* $o
94 %.segenco.ppm: %.segenco.ps Makefile
95 gs -dNOPAUSE -dBATCH -dSAFER -q \
96 -sDEVICE=ppmraw -r72 -g595x842 \
97 -sOutputFile=$@.new $< && mv -f $@.new $@
99 ours.graph.c: extractgraph ours.dgram-bot.p0.segenco.ps
101 # Strictly, this is wrong as it only uses layer 0. When we have more
102 # layers, should put them all in same segenco specially for extractgraph
104 ours-l%.ps: ours.d4 layout
105 ./layout <$< -l$* $(LAYOUTOPTS) $(XLAYOUTOPTS_LAYER) $o
107 ours-e%.ps: ours.d4 layout
108 ./layout <$< -l$* -E'=*aRsclMno' \
109 -e'p=*rm' -e'=5RN' -E'*~=5rsm' -e'p~=5r' -e'*=*l' $o
111 ours-p%.ps: ours.d4 layout
112 ./layout <$< -l$$(printf %s "$*" | sed -e 's/-/ -P/') \
113 $(LAYOUTOPTS_PHYS) $(XLAYOUTOPTS_LAYER) $o
115 parts.ps: showlib.d4 layout
116 ./layout <$< $(LAYOUTOPTS_ALL) $o
119 t.ppm: ours.dgram-bot.pa.segenco.ppm x.gdb subseg2display
122 ui-plan-%.ppm: ours.dgram-%.pa.segenco.ppm Makefile
123 pnmcrop <$< >$@.1.new
124 pnmflip <$@.1.new -ccw >$@.2.new
125 pnmpad <$@.2.new -white -l5 -r5 -t5 -b5 $o
127 subseg2display.o compose-segenco.o: segcmap.h
130 -rm -f -- *.d4 *~ t.* *.m *.new core
131 -rm -f ours-*.ps parts.ps
132 -rm -f *.oprint-*.ps *.run-layout
133 -rm -f *.segcmap *.segcmapreq
134 -rm -f *.dgram-*.p*.segenco.ps *.dgram-*.p*.segenco.ppm
135 -rm -f $(CPROGS) *.o *.d
137 .PRECIOUS: $(OPRINTS)
138 .PRECIOUS: %.segcmap %.segcmapreq %.segenco.ppm %.d4 %.neato %.raw.neato
139 .PRECIOUS: %.redactgraph %.redacted.forsafety %.redacted.neato
140 .PRECIOUS: %.layout-data.c
142 include $(wildcard *.d)