]> git.sur5r.net Git - cc65/blob - test/ref/Makefile
Merge pull request #142 from greg-king5/disassemble-segment
[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 REFS := $(patsubst %.c,$(WORKDIR)/%.ref,$(wildcard *.c))
30
31 SOURCES := $(wildcard *.c)
32 TESTS := $(SOURCES:%.c=$(WORKDIR)/%.prg)
33 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.o.prg)
34 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.os.prg)
35 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osi.prg)
36 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.osir.prg)
37 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oi.prg)
38 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.oir.prg)
39 TESTS += $(SOURCES:%.c=$(WORKDIR)/%.or.prg)
40
41 all: $(REFS) $(TESTS)
42
43 $(WORKDIR)/%.ref: %.c
44         $(CC) $(CFLAGS) $< -o $(WORKDIR)/$*.host
45         $(WORKDIR)/$*.host > $@
46
47 $(WORKDIR)/%.prg: %.c $(WORKDIR)/%.ref
48         $(CL65) $(CC65FLAGS) $< -o $@
49         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
50         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
51
52 $(WORKDIR)/%.o.prg: %.c $(WORKDIR)/%.ref
53         $(CL65) -O $(CC65FLAGS) $< -o $@
54         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
55         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
56
57 $(WORKDIR)/%.os.prg: %.c $(WORKDIR)/%.ref
58         $(CL65) -Os $(CC65FLAGS) $< -o $@
59         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
60         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
61
62 $(WORKDIR)/%.osi.prg: %.c $(WORKDIR)/%.ref
63         $(CL65) -Osi $(CC65FLAGS) $< -o $@
64         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
65         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
66
67 $(WORKDIR)/%.osir.prg: %.c $(WORKDIR)/%.ref
68         $(CL65) -Osir $(CC65FLAGS) $< -o $@
69         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
70         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
71
72 $(WORKDIR)/%.oi.prg: %.c $(WORKDIR)/%.ref
73         $(CL65) -Oi $(CC65FLAGS) $< -o $@
74         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
75         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
76
77 $(WORKDIR)/%.oir.prg: %.c $(WORKDIR)/%.ref
78         $(CL65) -Oir $(CC65FLAGS) $< -o $@
79         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
80         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
81
82 $(WORKDIR)/%.or.prg: %.c $(WORKDIR)/%.ref
83         $(CL65) -Or $(CC65FLAGS) $< -o $@
84         $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
85         $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
86
87 clean:
88         @$(RM) $(TESTS)
89         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.o)
90         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.out)
91         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.ref)
92         @$(RM) $(SOURCES:%.c=$(WORKDIR)/%.host)