]> git.sur5r.net Git - cc65/blob - test/val/Makefile
scan sources just once
[cc65] / test / val / Makefile
1
2 # makefile for the regression tests that return an error code on failure
3
4 ifneq ($(shell echo),)
5   CMD_EXE = 1
6 endif
7
8 CC65FLAGS = -t sim6502
9 SIM65FLAGS = -x 200000000
10
11 CL65 := $(if $(wildcard ../../bin/cl65*),../../bin/cl65,cl65)
12 SIM65 := $(if $(wildcard ../../bin/sim65*),../../bin/sim65,sim65)
13
14 ifdef CMD_EXE
15 RM := del /f
16 else
17 RM := rm -f
18 endif
19
20 WORKDIR := ./../../testwrk
21
22 .PHONY: all clean
23
24 SOURCES := $(wildcard *.c)
25 TESTS := $(SOURCES:%.c=$(WORKDIR)/%.prg)
26 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.o.prg)
27 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.os.prg)
28 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osi.prg)
29 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osir.prg)
30 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oi.prg)
31 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oir.prg)
32 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.or.prg)
33
34 all: $(TESTS)
35
36 $(WORKDIR)/%.prg: %.c
37         $(CL65) $(CC65FLAGS) $< -o $@
38         $(SIM65) $(SIM65FLAGS) $@
39
40 $(WORKDIR)/%.o.prg: %.c
41         $(CL65) -O $(CC65FLAGS) $< -o $@
42         $(SIM65) $(SIM65FLAGS) $@
43
44 $(WORKDIR)/%.os.prg: %.c
45         $(CL65) -Os $(CC65FLAGS) $< -o $@
46         $(SIM65) $(SIM65FLAGS) $@
47
48 $(WORKDIR)/%.osi.prg: %.c
49         $(CL65) -Osi $(CC65FLAGS) $< -o $@
50         $(SIM65) $(SIM65FLAGS) $@
51
52 $(WORKDIR)/%.osir.prg: %.c
53         $(CL65) -Osir $(CC65FLAGS) $< -o $@
54         $(SIM65) $(SIM65FLAGS) $@
55
56 $(WORKDIR)/%.oi.prg: %.c
57         $(CL65) -Oi $(CC65FLAGS) $< -o $@
58         $(SIM65) $(SIM65FLAGS) $@
59
60 $(WORKDIR)/%.oir.prg: %.c
61         $(CL65) -Oir $(CC65FLAGS) $< -o $@
62         $(SIM65) $(SIM65FLAGS) $@
63
64 $(WORKDIR)/%.or.prg: %.c
65         $(CL65) -Or $(CC65FLAGS) $< -o $@
66         $(SIM65) $(SIM65FLAGS) $@
67
68 clean:
69         @$(RM) $(TESTS)
70         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.o)