]> 4ch.mooo.com Git - 16.git/blob - makefile
db.exe added as a utility
[16.git] / makefile
1 #
2 #       Higanbana Project makefile
3 #
4 #
5 # Possible optimizations for 8088 class processors
6 #
7 # -oa   Relax alias checking
8 # -ob   Try to generate straight line code
9 # -oe - expand user functions inline (-oe=20 is default, adds lots of code)
10 # -oh   Enable repeated optimizations
11 # -oi   generate certain lib funcs inline
12 # -oi   +Set max inline depth (C++ only, use -oi for C)
13 # -ok   Flowing of register save into function flow graph
14 # -ol   loop optimizations
15 # -ol+  loop optimizations plus unrolling
16 # -or   Reorder for pipelined (486+ procs); not sure if good to use
17 # -os   Favor space over time
18 # -ot   Favor time over space
19 # -ei   Allocate an "int" for all enum types
20 # -zp2  Allow compiler to add padding to structs
21 # -zpw  Use with above; make sure you are warning free!
22 # -0    8088/8086 class code generation
23 # -s    disable stack overflow checking
24
25 # -zk0u translate kanji to unicode... wwww
26 # -zk0  kanji support~
27 # -zkl          current codepage
28
29 # this enables debug output to the serial port.
30 # comment this out on game release.
31 # serial output goes to COM1 at 9600 baud 1 stop bit odd parity.
32 # serial output is plain text ASCII.
33 DEBUGSERIAL=1
34
35 #192x144
36 #wwww will add these
37 !ifdef __LINUX__
38 #!ifdef UNIX
39 to_os_path=\=/
40 REMOVECOMMAND=rm -f
41 COPYCOMMAND=cp -f
42 DIRSEP=/
43 OBJ=obj
44 DUMP=cat
45 DOSLIBMAKE=./make.sh
46 DOSLIBMAKEALL=./buildall.sh
47 !else           #DOS ^^
48 to_os_path=/=\
49 REMOVECOMMAND=del
50 COPYCOMMAND=copy /y
51 DIRSEP=\
52 OBJ=obj
53 DUMP=type
54 DOSLIBMAKE=.\make.bat
55 DOSLIBMAKEALL=.\build.bat
56 !endif
57
58 TARGET_OS = dos
59
60 BUILD_ROOT=$+$(%__CWD__)$-
61 #EXMMTESTDIR=16$(DIRSEP)exmmtest$(DIRSEP)
62 DATADIR=data$(DIRSEP)
63 SPRI=$(DATADIR)/spri
64 SRC=src
65 SRCLIB=src/lib
66 JSMNLIB=src/lib/jsmn
67 NYANLIB=src/lib/nyan
68 EXMMLIB=src/lib/exmm
69 MODEXLIB16=src/lib/16_vl
70 MODEXLIB=src/lib/modex
71 VGMSNDLIB=src/lib/vgmsnd
72 DOSLIB=src/lib/doslib
73 WCPULIB=src/lib/wcpu
74
75 DOSLIB_CPU=src/lib/doslib/hw/cpu
76 DOSLIB_DOS=src/lib/doslib/hw/dos
77 DOSLIB_VGA=src/lib/doslib/hw/vga
78 DOSLIB_8250=src/lib/doslib/hw/8250
79 DOSLIB_JOYSTICK=src/lib/doslib/hw/joystick
80
81 #
82 # quiet flags
83 #
84 WLIBQ=-q
85 WCLQ=-q
86 UPXQ=-qqq
87
88 #
89 # compile flags
90 #
91 S_FLAGS=-sg -st -of+ -zu -zdf -zff -zgf -zq -k32768#54096#60000
92 Z_FLAGS=-zk0 -zc -zp8 -zm
93 O_FLAGS=-obmilr -oe=24 -out -oh -ei -onac -ol+ -ok##x
94 T_FLAGS=-bt=dos -wx -mh -0 -fpi87 -fo=.$(OBJ) -d1###### -e=65536
95
96 CPPFLAGS=-DTARGET_MSDOS=16 -DMSDOS=1
97 !ifeq DEBUGSERIAL 1
98 CPPFLAGS += -DDEBUGSERIAL
99 !endif
100 AFLAGS=$(WCLQ) $(T_FLAGS)
101 CFLAGS=$(WCLQ) $(T_FLAGS) -wo -i"$(DOSLIB)" $(O_FLAGS) $(S_FLAGS) $(Z_FLAGS)
102 LFLAGS=$(WCLQ) -l=dos -fm=$^&.mah $(S_FLAGS)
103 LIBFLAGS=$(WLIBQ) -b -n
104
105 #
106 # objects
107 #
108 VGMSNDOBJ = vgmSnd.$(OBJ) 16_snd.$(OBJ)
109 OLDLIBOBJS=bitmap.$(OBJ) mapread.$(OBJ) 16render.$(OBJ)
110 GFXLIBOBJS = 16_vl.$(OBJ) 16text.$(OBJ) bakapee.$(OBJ) scroll16.$(OBJ) 16_vrs.$(OBJ) 16_sprit.$(OBJ) $(OLDLIBOBJS)
111 16LIBOBJS = 16_mm.$(OBJ) 16_pm.$(OBJ) 16_ca.$(OBJ) 16_tail.$(OBJ) 16_in.$(OBJ) 16_head.$(OBJ) 16_dbg.$(OBJ) kitten.$(OBJ) 16_hc.$(OBJ) wcpu.$(OBJ) 16_timer.$(OBJ) jsmn.$(OBJ)
112 #16planar.$(OBJ) planar.$(OBJ)
113 DOSLIBOBJ = adlib.$(OBJ) 8254.$(OBJ) 8259.$(OBJ) dos.$(OBJ) cpu.$(OBJ)
114 !ifeq DEBUGSERIAL 1
115 DOSLIBOBJ += 8250.$(OBJ)
116 !endif
117
118 #
119 # libraries
120 #
121 DOSLIBLIBS = $(DOSLIB_CPU)/dos86h/cpu.lib $(DOSLIB_DOS)/dos86h/dos.lib $(DOSLIB_VGA)/dos86h/vga.lib
122 !ifeq DEBUGSERIAL 1
123 DOSLIBLIBS += $(DOSLIB_8250)/dos86h/8250.lib
124 !endif
125 16LIB=$(16LIBOBJS)#16.lib bad program lock up
126
127 #
128 #       Files locations
129 #
130 .c : $(SRC);$(SRCLIB);$(MODEXLIB16);$(JSMNLIB);$(NYANLIB);$(VGMSNDLIB);$(WCPULIB)
131
132 .asm : $(MODEXLIB)
133
134 .lib : .;$(DOSLIB_CPU)/dos86h;$(DOSLIB_DOS)/dos86h;$(DOSLIB_VGA)/dos86h;$(DOSLIB_8250)/dos86h
135
136 .obj : .
137
138 #
139 #       Default make rules
140 #
141 .c.obj:
142         *wcl $(CPPFLAGS) $(CFLAGS) $(extra_$^&_obj_opts) -c $[@
143
144 .asm.obj:
145         *wcl $(AFLAGS) $(extra_$^&_obj_opts) -c $[@
146
147 #CFLAGS is neccessary here
148 .obj.exe :
149         *wcl $(LFLAGS) $(extra_$^&_exe_opts) -fe=$@ $<
150
151 .obj.lib :
152         *wlib $(LIBFLAGS) $(extra_$^&_lib_opts) $@ $<
153
154 #
155 # List of executables to build
156 #
157 TESTEXEC = &
158         tesuto.exe &
159         0.exe &
160         exmmtest.exe &
161         vgmtest.exe &
162         scroll.exe &
163         zcroll.exe &
164         vrstest.exe
165 TESTEXEC2 = &
166         inputest.exe &
167         maptest.exe &
168         fmemtest.exe &
169         fonttest.exe &
170         fontgfx.exe &
171         test.exe &
172         test0.exe &
173         pcxtest.exe &
174         pcxtest2.exe
175 UTILEXEC = &
176         palettel.exe &
177         palettec.exe &
178         db.exe
179 EXEC = &
180         16.exe &
181         bakapi.exe &
182         $(UTILEXEC) &
183         $(TESTEXEC)
184
185 all: $(EXEC) joytest.exe
186 testexec: $(EXEC) joytest.exe $(TESTEXEC2)
187
188 #
189 # game and bakapi executables
190 #
191 16.exe:         16.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
192 bakapi.exe:             bakapi.$(OBJ) gfx.lib $(DOSLIBLIBS)
193
194 #
195 # Test Executables!
196 #
197 scroll.exe:     scroll.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
198 scroll.$(OBJ):  $(SRC)/scroll.c
199 zcroll.exe:     zcroll.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
200 zcroll.$(OBJ):  $(SRC)/zcroll.c
201 tesuto.exe:     tesuto.$(OBJ) 16_head.$(OBJ) gfx.lib $(DOSLIBLIBS)
202 tesuto.$(OBJ):  $(SRC)/tesuto.c
203 0.exe:                  0.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
204 0.$(OBJ):                $(SRC)/0.c
205 test.exe:                test.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
206 #test2.exe:     test2.$(OBJ) gfx.lib $(DOSLIBLIBS)
207 test0.exe:              test0.$(OBJ)
208 fonttest.exe:    fonttest.$(OBJ) gfx.lib
209 #fonttes0.exe:  fonttes0.$(OBJ) $(16LIB)
210 fontgfx.exe:    fontgfx.$(OBJ) gfx.lib $(DOSLIBLIBS)
211 inputest.exe:    inputest.$(OBJ) $(16LIB) $(DOSLIBLIBS)
212 #sountest.exe:  sountest.$(OBJ) $(16LIB)
213 pcxtest.exe:    pcxtest.$(OBJ) gfx.lib $(DOSLIBLIBS)
214 vrstest.exe:    vrstest.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
215 #vgacamm.exe:   vgacamm.$(OBJ) $(16LIB) gfx.lib $(DOSLIBLIBS)
216 palettec.exe:    palettec.$(OBJ) gfx.lib $(DOSLIBLIBS)
217 palettel.exe:    palettel.$(OBJ) gfx.lib $(DOSLIBLIBS)
218 pcxtest2.exe:    pcxtest2.$(OBJ) gfx.lib $(DOSLIBLIBS)
219 #planrpcx.exe:  planrpcx.$(OBJ) gfx.lib
220 maptest.exe:    maptest.$(OBJ) 16_map.$(OBJ) 16_head.$(OBJ) gfx.lib $(DOSLIBLIBS)
221 fmemtest.exe:    fmemtest.$(OBJ)
222 exmmtest.exe:    exmmtest.$(OBJ) $(16LIB) $(DOSLIBLIBS)
223 vgmtest.exe:    vgmtest.$(OBJ) vgmsnd.lib $(16LIB) $(DOSLIBLIBS)
224 db.exe:         db.$(OBJ)
225
226 #
227 # executable's objects
228 #
229 16.$(OBJ):              $(SRC)/16.c $(SRC)/16.h
230 bakapi.$(OBJ):  $(SRC)/bakapi.c $(SRC)/bakapi.h
231 test.$(OBJ):    $(SRC)/test.c $(SRCLIB)/16_vl.h
232 #test2.$(OBJ):  $(SRC)/test2.c $(SRCLIB)/16_vl.h
233 test0.$(OBJ):    $(SRC)/test0.c
234 pcxtest.$(OBJ):$(SRC)/pcxtest.c $(SRCLIB)/16_vl.h
235 vrstest.$(OBJ):$(SRC)/vrstest.c $(SRCLIB)/16_vl.h
236 #vgacamm.$(OBJ):$(SRC)/vgacamm.c $(SRCLIB)/16_vl.h
237 #planrpcx.$(OBJ): $(SRC)/planrpcx.c $(SRCLIB)/16_vl.h
238 pcxtest2.$(OBJ):$(SRC)/pcxtest2.c $(SRCLIB)/16_vl.h
239 palettec.$(OBJ):$(SRC)/palettec.c
240 palettel.$(OBJ):$(SRC)/palettel.c
241 maptest.$(OBJ):$(SRC)/maptest.c $(SRCLIB)/16_vl.h
242 #emmtest.$(OBJ):$(SRC)/emmtest.c
243 #emsdump.$(OBJ):$(SRC)/emsdump.c
244 fmemtest.$(OBJ):$(SRC)/fmemtest.c
245 fonttest.$(OBJ):$(SRC)/fonttest.c
246 #fonttes0.$(OBJ): $(SRC)/fonttes0.c
247 fontgfx.$(OBJ):$(SRC)/fontgfx.c
248 inputest.$(OBJ):$(SRC)/inputest.c
249 #sountest.$(OBJ): $(SRC)/sountest.c
250 #miditest.$(OBJ): $(SRC)/miditest.c
251 #testemm.$(OBJ):$(SRC)/testemm.c
252 #testemm0.$(OBJ): $(SRC)/testemm0.c
253 #tsthimem.$(OBJ): $(SRC)/tsthimem.c
254 exmmtest.$(OBJ):$(SRC)/exmmtest.c
255 vgmtest.$(OBJ):$(SRC)/vgmtest.c
256 db.$(OBJ):$(SRC)/db.c
257
258 #
259 # non executable objects libraries
260 #
261 16.lib: $(16LIBOBJS)
262 vgmsnd.lib: $(VGMSNDOBJ)
263
264 gfx.lib: $(GFXLIBOBJS)
265         *wlib $(LIBFLAGS) $(extra_$^&_lib_opts) $@ $<
266
267 #
268 #       doslib
269 #
270 # library deps 16-bit huge
271 $(DOSLIB_CPU)/dos86h/cpu.lib:
272         cd $(DOSLIB_CPU:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
273 $(DOSLIB_DOS)/dos86h/dos.lib:
274         cd $(DOSLIB_DOS:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
275 $(DOSLIB_VGA)/dos86h/vgatty.lib:
276         cd $(DOSLIB_VGA:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
277 $(DOSLIB_VGA)/dos86h/vga.lib:
278         cd $(DOSLIB_VGA:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
279 $(DOSLIB_8250)/dos86h/8250.lib:
280         cd $(DOSLIB_8250:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
281
282 joytest.exe:
283         cd $(DOSLIB_JOYSTICK:$(to_os_path)) && $(DOSLIBMAKE) && cd $(BUILD_ROOT)
284         $(COPYCOMMAND) $(DOSLIB_JOYSTICK:$(to_os_path))$(DIRSEP)dos86h$(DIRSEP)test.exe joytest.exe
285
286 16_vl.$(OBJ):$(SRCLIB)/16_vl.c $(SRCLIB)/16_vl.h
287 bakapee.$(OBJ):$(SRCLIB)/bakapee.c $(SRCLIB)/bakapee.h
288 16render.$(OBJ):$(SRCLIB)/16render.c $(SRCLIB)/16render.h
289 16planar.$(OBJ):$(MODEXLIB16)/16planar.c $(MODEXLIB16)/16planar.h
290 16_vrs.$(OBJ):  $(SRCLIB)/16_vrs.c $(SRCLIB)/16_vrs.h $(DOSLIBLIBS)
291 16_sprit.$(OBJ):$(SRCLIB)/16_sprit.c $(SRCLIB)/16_sprit.h
292 bitmap.$(OBJ):  $(SRCLIB)/bitmap.c $(SRCLIB)/bitmap.h
293 planar.$(OBJ):  $(SRCLIB)/planar.c $(SRCLIB)/planar.h
294 scroll16.$(OBJ):$(SRCLIB)/scroll16.c $(SRCLIB)/scroll16.h
295 16text.$(OBJ):  $(SRCLIB)/16text.c
296 mapread.$(OBJ):$(SRCLIB)/mapread.c $(SRCLIB)/mapread.h
297 16_map.$(OBJ):$(SRCLIB)/16_map.c $(SRCLIB)/16_map.h
298 16_timer.$(OBJ):$(SRCLIB)/16_timer.c $(SRCLIB)/16_timer.h
299 16_in.$(OBJ):    $(SRCLIB)/16_in.c $(SRCLIB)/16_in.h
300 16_mm.$(OBJ):    $(SRCLIB)/16_mm.c $(SRCLIB)/16_mm.h
301 16_pm.$(OBJ):    $(SRCLIB)/16_pm.c $(SRCLIB)/16_pm.h
302 16_ca.$(OBJ):    $(SRCLIB)/16_ca.c $(SRCLIB)/16_ca.h
303 16_dbg.$(OBJ):  $(SRCLIB)/16_dbg.c $(SRCLIB)/16_dbg.h
304 midi.$(OBJ):    $(SRCLIB)/midi.c $(SRCLIB)/midi.h
305 16_head.$(OBJ):$(SRCLIB)/16_head.c $(SRCLIB)/16_head.h
306 16_tail.$(OBJ):$(SRCLIB)/16_tail.c $(SRCLIB)/16_tail.h
307 16_hc.$(OBJ):    $(SRCLIB)/16_hc.c $(SRCLIB)/16_hc.h
308 16_snd.$(OBJ):  $(SRCLIB)/16_snd.c $(SRCLIB)/16_snd.h
309 jsmn.$(OBJ):    $(JSMNLIB)/jsmn.c $(JSMNLIB)/jsmn.h
310 kitten.$(OBJ):  $(NYANLIB)/kitten.c $(NYANLIB)/kitten.h
311 vgmSnd.$(OBJ):  $(VGMSNDLIB)/vgmSnd.c $(VGMSNDLIB)/vgmSnd.h
312 wcpu.$(OBJ):    $(WCPULIB)/wcpu.c $(WCPULIB)/wcpu.h
313 #memory.$(OBJ):$(EXMMLIB)/memory.c $(EXMMLIB)/memory.h
314 c_utils.$(OBJ):$(MODEXLIB)/c_utils.asm
315 modex.$(OBJ):    $(MODEXLIB)/modex.asm
316
317 #
318 #other~
319 #
320 clean: .symbolic
321         @for %f in ($(EXEC)) do @if exist %f $(REMOVECOMMAND) %f
322 !ifdef __LINUX__
323         @rm *.LIB
324         @. src/util/bcexmm.sh
325         @rm *.EXE
326 !endif
327         @if exist *.obj $(REMOVECOMMAND) *.obj
328         @if exist *.OBJ $(REMOVECOMMAND) *.OBJ
329         @if exist *.bco $(REMOVECOMMAND) *.bco
330         @if exist *.BCO $(REMOVECOMMAND) *.BCO
331         @if exist *.LIB $(REMOVECOMMAND) *.LIB
332         @if exist *.lnk $(REMOVECOMMAND) *.lnk
333         @if exist *.LNK $(REMOVECOMMAND) *.LNK
334         @if exist *.smp $(REMOVECOMMAND) *.smp
335         @if exist *.SMP $(REMOVECOMMAND) *.SMP
336         @if exist *.hed $(REMOVECOMMAND) *.hed
337         @if exist *.mah $(REMOVECOMMAND) *.mah
338         @if exist *.MAH $(REMOVECOMMAND) *.MAH
339         @if exist *.err $(REMOVECOMMAND) *.err
340 #       @if exist *.16W $(REMOVECOMMAND) *.16W
341 #       @if exist *.16B $(REMOVECOMMAND) *.16B
342
343 #       @$(COPYCOMMAND) $(SRC)exmmtest.c $(EXMMTESTDIR)$(SRC)
344 #       @$(COPYCOMMAND) $(SRCLIB)16_mm.* $(EXMMTESTDIR)$(SRCLIB)
345 #       @$(COPYCOMMAND) $(SRCLIB)16_head.* $(EXMMTESTDIR)$(SRCLIB)
346 #       @$(COPYCOMMAND) $(SRCLIB)16_ca.* $(EXMMTESTDIR)$(SRCLIB)
347 #       @$(COPYCOMMAND) $(SRCLIB)16_hc.* $(EXMMTESTDIR)$(SRCLIB)
348 #       @$(COPYCOMMAND) $(SRCLIB)types.h $(EXMMTESTDIR)$(SRCLIB)
349 #       @$(COPYCOMMAND) $(NYANLIB)* $(EXMMTESTDIR)$(NYANLIB)
350
351 nuke: .symbolic
352         @wmake clean
353         @wmake cldl
354         @wmake all
355         @wmake comp
356
357 backupconfig: .symbolic
358         @$(COPYCOMMAND) .git$(DIRSEP)config git_con.fig
359         @$(COPYCOMMAND) .gitmodules git_modu.les
360         @$(COPYCOMMAND) .gitignore git_igno.re
361
362 comp: .symbolic
363         @*upx -9 $(EXEC)
364
365 comq: .symbolic
366         @*upx -9 $(UPXQ) $(EXEC)
367
368 www: .symbolic
369         @ssh -p 26 sparky4@4ch.mooo.com 'rm -f /var/www/16/*exe*'
370         #@rm -f /var/www/$(EXEC)*
371         @rm -f /var/www/*.exe.zip*
372         #@cp ./$(EXEC) $(DIRSEP)var$(DIRSEP)www$(DIRSEP)
373         @./src/util/z.sh $(EXEC) $(EXEC)
374         @scp -r -P 26 *.exe 4ch.mooo.com:/var/www/16/
375         @scp -r -P 26 x4get.bat 4ch.mooo.com:/var/www/16/
376         @scp -r -P 26 /var/www/*.exe.zip.* 4ch.mooo.com:/var/www/16/
377
378 getwww: .symbolic
379         *x4get.bat $(EXEC)
380
381 vomitchan: .symbolic
382         @if exist *.err $(DUMP) *.err
383
384 ##
385 ##      External library management~ ^^
386 ##
387 #git submodule add <repo>
388 mkdl: .symbolic
389         @cd $(DOSLIB:$(to_os_path))
390         @$(DOSLIBMAKEALL)
391         @cd $(BUILD_ROOT)
392
393 cldl: .symbolic
394         @cd $(DOSLIB:$(to_os_path))
395         @$(DOSLIBMAKEALL) clean
396         @cd $(BUILD_ROOT)
397
398 uplibs: .symbolic
399         @cd $(JSMNLIB:$(to_os_path))
400         @git pull
401         @cd $(BUILD_ROOT)
402         @cd $(DOSLIB:$(to_os_path))
403         @git pull
404         @cd $(BUILD_ROOT)
405
406 reinitlibs: .symbolic
407         @rm -rf $(DOSLIB)
408         @rm -rf $(JSMNLIB)
409         @rm -rf 16/CatacombApocalypse
410         @rm -rf 16/wolf3d
411         @rm -rf 16/keen
412         @rm -rf 16/Catacomb3D
413         @wmake -h initlibs
414
415 initlibs: .symbolic
416         @cp git_con.fig .git/config
417         @cp git_modu.les .gitmodules
418         @cp git_igno.re .gitignore
419         @cd $(SRCLIB:$(to_os_path))
420         @git clone https://github.com/joncampbell123/doslib.git
421         @git clone https://github.com/zserge/jsmn.git
422         @cd $(BUILD_ROOT)
423         @cd 16
424         @git clone https://github.com/FlatRockSoft/CatacombApocalypse.git
425         @git clone https://github.com/id-Software/wolf3d.git
426         @git clone https://github.com/keendreams/keen.git
427         @git clone https://github.com/FlatRockSoft/Catacomb3D.git
428         @cd $(BUILD_ROOT)
429         @cp $(DOSLIB)/make-lowercase .
430
431 ##
432 ##      experimental libs
433 ##
434 xlib: .symbolic
435         @cd 16$(DIRSEP)xlib
436         @wmake -h clean
437         @wmake -h all
438         @cd $(BUILD_ROOT)
439
440 mx: .symbolic
441         @cd 16$(DIRSEP)xw
442 #       @wmake clean
443         @wmake -h all
444         @cd $(BUILD_ROOT)
445
446 mx_: .symbolic
447         @cd 16$(DIRSEP)xw_
448         @wmake -h -f makefile all
449         @cd $(BUILD_ROOT)
450
451 vrs: .symbolic
452         @cd $(DOSLIB_VGA:$(to_os_path))
453         #@make clean
454         @make all
455         @mv pcx2vrl $(BUILD_ROOT)$(DIRSEP)
456         @mv pcxsscut $(BUILD_ROOT)$(DIRSEP)
457         @mv vrl2vrs $(BUILD_ROOT)$(DIRSEP)
458         @mv vrsdump $(BUILD_ROOT)$(DIRSEP)
459         @cd $(BUILD_ROOT)