]> git.sur5r.net Git - cc65/blob - test/ref/Makefile
Use simply-defined make variables.
[cc65] / test / ref / Makefile
1
2 # makefile for the regression tests that generate output which has to be
3 # compared with reference output
4
5 ifneq ($(shell echo),)
6   CMD_EXE := 1
7 endif
8
9 CC65FLAGS := -t sim6502
10 SIM65FLAGS := -x 200000000
11
12 CL65 := $(if $(wildcard ../../bin/cl65*),../../bin/cl65,cl65)
13 SIM65 := $(if $(wildcard ../../bin/sim65*),../../bin/sim65,sim65)
14
15 ifdef CMD_EXE
16 RM := del /f
17 else
18 RM := rm -f
19 endif
20
21 WORKDIR := ../../testwrk
22
23 DIFF := $(WORKDIR)/bdiff
24
25 CFLAGS := -O2 -Wall -W -Wextra -fwrapv -fno-strict-overflow
26
27 .PHONY: all clean
28
29 SOURCES := $(wildcard *.c)
30
31 REFS := $(SOURCES:%.c=$(WORKDIR)/%.ref)
32
33 TESTS := $(SOURCES:%.c=$(WORKDIR)/%.prg)
34 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.o.prg)
35 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.os.prg)
36 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osi.prg)
37 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osir.prg)
38 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oi.prg)
39 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oir.prg)
40 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.or.prg)
41
42 all: $(REFS) $(TESTS)
43
44 $(WORKDIR)/%.ref: %.c
45         $(CC) $(CFLAGS) $< -o $(WORKDIR)/$*.host
46         $(WORKDIR)/$*.host > $@
47
48 $(WORKDIR)/%.prg: %.c $(WORKDIR)/%.ref
49         $(CL65) $(CC65FLAGS) $< -o $@
50         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
51         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
52
53 $(WORKDIR)/%.o.prg: %.c $(WORKDIR)/%.ref
54         $(CL65) -O $(CC65FLAGS) $< -o $@
55         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
56         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
57
58 $(WORKDIR)/%.os.prg: %.c $(WORKDIR)/%.ref
59         $(CL65) -Os $(CC65FLAGS) $< -o $@
60         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
61         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
62
63 $(WORKDIR)/%.osi.prg: %.c $(WORKDIR)/%.ref
64         $(CL65) -Osi $(CC65FLAGS) $< -o $@
65         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
66         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
67
68 $(WORKDIR)/%.osir.prg: %.c $(WORKDIR)/%.ref
69         $(CL65) -Osir $(CC65FLAGS) $< -o $@
70         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
71         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
72
73 $(WORKDIR)/%.oi.prg: %.c $(WORKDIR)/%.ref
74         $(CL65) -Oi $(CC65FLAGS) $< -o $@
75         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
76         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
77
78 $(WORKDIR)/%.oir.prg: %.c $(WORKDIR)/%.ref
79         $(CL65) -Oir $(CC65FLAGS) $< -o $@
80         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
81         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
82
83 $(WORKDIR)/%.or.prg: %.c $(WORKDIR)/%.ref
84         $(CL65) -Or $(CC65FLAGS) $< -o $@
85         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
86         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
87
88 clean:
89         @$(RM) $(TESTS)
90         @$(RM) $(SOURCES:.c=.o)
91         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.out)
92         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.ref)
93         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.host)