chiark / gitweb /
makes ui-plan-bot.c
[trains.git] / layout / Makefile
1 include ../cprogs.make
2 include ../common.make
3
4 M4INCS=         parts.i4
5
6 E_TRACK=        ArsCLMNo
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'
11
12 LAYOUTOPTS_SEGS= '-e*=*rm'
13
14 LAYERS_LS=      0 10 20
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)
19
20 LPAGES=  $(foreach x, 0 1 2 3 4 5 6, $(foreach y, 1 2 3 4 5, ours-p0-$xx$y.ps))
21
22 CPROGS=         subseg2display compose-segenco
23
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
29
30 layers:         $(LAYERS)
31 lpages:         $(LPAGES)
32 extras:         dualjn-a.ps parts.ps
33
34 include ours.dgram.m
35 include segencolayers.m
36
37 NETPBM=         -lnetpbm
38 # -lppm
39
40 REDACT=         consistency movfeatsplitedges   \
41                 consistency movfeatrmstubs      \
42                 consistency movfeatsplitnodes   \
43                 consistency trivpairnodes       \
44                 consistency trivnullnodes
45
46 subseg2display: subseg2display.o
47                 $(LINK) $(NETPBM) -lpub -lm
48
49 compose-segenco: compose-segenco.o
50                 $(LINK) $(NETPBM)
51
52 %.neato.ps:     %.neato
53                 neato -Tps <$< $o
54
55 %.raw.neato:    %.redactgraph
56                 ./$< consistency printforneato $o
57
58 %.redacted.neato: %.redactgraph
59                 ./$< $(REDACT) consistency printforneato $o
60
61 %.redacted.forsafety: %.redactgraph
62                 ./$< $(REDACT) consistency printforforsafety $o
63
64 %.layout-data.c: data2safety %.wiring %.redacted.forsafety \
65                         reversers.pin-info detectors.pin-info
66                 ./$(filter-out %.pin-info, $^) $o
67
68 %-pindata.asm:  %.layout-data.c
69                 @:
70
71 ui-plan-%.c:    plan-to-gui-data ours.dgram-%.segcmap ui-plan-%.ppm
72                 ./$+ $o
73
74 %.pin-info:     pin-info-gen ../pcb/%.net
75                 ./$< $* $o
76
77 %.redactgraph:  %.graph.o redactgraph.o
78                 $(LINK)
79
80 %.d4:           %.m4 $(M4INCS) Makefile
81                 m4 -s <$< $o
82
83 %-a.ps:         %.d4 layout
84                 ./layout <$< $(LAYOUTOPTS) '-E*l' $o
85
86 %-al.ps:        %.d4 layout
87                 ./layout <$< $(LAYOUTOPTS) '-e*C' '-ep=rm' $o
88
89 %-ap.ps:        %.d4 layout
90                 ./layout -S1.0 <$< $(LAYOUTOPTS) '-e*A' '-ep=rm' $o
91
92 %.segcmapreq:   %.run-layout
93                 ./$< $(LAYOUTOPTS_SEGS) -GR $o
94
95 %.segcmap:      %.segcmapreq segcmapassign segcmap.h
96                 ./segcmapassign <$< $o
97
98 %.dgram.m:      %.dgram-list make-dgram-make
99                 ./make-dgram-make <$< $* $o
100
101 %.m:            %.gen-make
102                 ./$< $o
103
104 %.segenco.ppm:  %.segenco.ps Makefile
105                 gs -dNOPAUSE -dBATCH -dSAFER -q \
106                         -sDEVICE=ppmraw -r72 -g595x842 \
107                         -sOutputFile=$@.new $< && mv -f $@.new $@
108
109 ours.graph.c:   extractgraph ours.dgram-bot.p0.segenco.ps
110                 ./$^ $o
111 # Strictly, this is wrong as it only uses layer 0.  When we have more
112 # layers, should put them all in same segenco specially for extractgraph
113
114 ours-l%.ps:     ours.d4 layout
115                 ./layout <$< -l$* $(LAYOUTOPTS) $(XLAYOUTOPTS_LAYER) $o
116
117 ours-e%.ps:     ours.d4 layout
118                 ./layout <$< -l$* -E'=*aRsclMno' \
119                         -e'p=*rm' -e'=5RN' -E'*~=5rsm' -e'p~=5r' -e'*=*l' $o
120
121 ours-p%.ps:     ours.d4 layout
122                 ./layout <$< -l$$(printf %s "$*" | sed -e 's/-/ -P/') \
123                         $(LAYOUTOPTS_PHYS) $(XLAYOUTOPTS_LAYER) $o
124
125 parts.ps:       showlib.d4 layout
126                 ./layout <$< $(LAYOUTOPTS_ALL) $o
127
128 # test case
129 t.ppm:          ours.dgram-bot.pa.segenco.ppm x.gdb subseg2display
130                 gdb -x x.gdb
131
132 ui-plan-%.ppm:  ours.dgram-%.pa.segenco.ppm Makefile
133                 pnmcrop <$< >$@.1.new
134                 pnmflip <$@.1.new -ccw >$@.2.new
135                 pnmpad <$@.2.new -white -l5 -r5 -t5 -b5 $o
136
137 subseg2display.o compose-segenco.o: segcmap.h
138
139 clean:
140                 -rm -f -- *.d4 *~ t.* *.m *.new core
141                 -rm -f ours-*.ps parts.ps
142                 -rm -f *.oprint-*.ps *.run-layout
143                 -rm -f *.segcmap *.segcmapreq
144                 -rm -f *.dgram-*.p*.segenco.ps *.dgram-*.p*.segenco.ppm
145                 -rm -f $(CPROGS) *.o *.d
146
147 .PRECIOUS:      $(OPRINTS)
148 .PRECIOUS:      %.segcmap %.segcmapreq %.segenco.ppm %.d4 %.neato %.raw.neato
149 .PRECIOUS:      %.redactgraph %.redacted.forsafety %.redacted.neato
150 .PRECIOUS:      %.layout-data.c
151
152 include $(wildcard *.d)