1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-10 19:29:45 +00:00

use testwrk for binaries, and generated reference data

This commit is contained in:
mrdudz 2014-11-25 13:47:31 +01:00
parent 9c03326360
commit 60026925ad
5 changed files with 98 additions and 94 deletions

View File

@ -11,10 +11,12 @@ ifdef CMD_EXE
RM := del /f RM := del /f
EXE := .exe EXE := .exe
MKDIR = mkdir MKDIR = mkdir
RMDIR = rmdir
else else
RM := rm -f RM := rm -f
EXE := EXE :=
MKDIR = mkdir -p MKDIR = mkdir -p
RMDIR = rmdir
endif endif
WORKDIR := ../testwrk WORKDIR := ../testwrk
@ -41,3 +43,4 @@ clean:
@$(MAKE) -C err clean @$(MAKE) -C err clean
@$(MAKE) -C misc clean @$(MAKE) -C misc clean
@$(RM) $(WORKDIR)/bdiff$(EXE) @$(RM) $(WORKDIR)/bdiff$(EXE)
@$(RMDIR) $(WORKDIR)

View File

@ -19,33 +19,33 @@ WORKDIR := ./../../testwrk
.PHONY: all clean .PHONY: all clean
TESTS := $(patsubst %.c,%.prg,$(wildcard *.c)) TESTS := $(patsubst %.c,$(WORKDIR)/%.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.o.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.o.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.os.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.os.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.or.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.or.prg,$(wildcard *.c))
all: $(TESTS) all: $(TESTS)
%.prg: %.c $(WORKDIR)/%.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.o.prg: %.c $(WORKDIR)/%.o.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.os.prg: %.c $(WORKDIR)/%.os.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.osi.prg: %.c $(WORKDIR)/%.osi.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.osir.prg: %.c $(WORKDIR)/%.osir.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.oi.prg: %.c $(WORKDIR)/%.oi.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.oir.prg: %.c $(WORKDIR)/%.oir.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
%.or.prg: %.c $(WORKDIR)/%.or.prg: %.c
! $(CL65) $(CC65FLAGS) $< -o $@ ! $(CL65) $(CC65FLAGS) $< -o $@
clean: clean:
@$(RM) *.o @$(RM) $(TESTS)
@$(RM) *.prg @$(RM) $(patsubst %.c,$(WORKDIR)/%.o,$(wildcard *.c))

View File

@ -23,41 +23,42 @@ DIFF := $(WORKDIR)/bdiff
.PHONY: all clean .PHONY: all clean
TESTS := $(patsubst %.c,%.prg,$(wildcard *.c)) TESTS := $(patsubst %.c,$(WORKDIR)/%.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.o.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.o.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.os.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.os.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.or.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.or.prg,$(wildcard *.c))
all: $(TESTS) all: $(TESTS)
# should compile, but then hangs in an endless loop # should compile, but then hangs in an endless loop
endless%prg: endless.c $(WORKDIR)/endless%prg: endless.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
! $(SIM65) $(SIM65FLAGS) $@ ! $(SIM65) $(SIM65FLAGS) $@
# these need reference data that cant be generated by a host compiled program # these need reference data that cant be generated by a host compiled program
# in a useful way # in a useful way
limits%prg: limits.c $(WORKDIR)/limits%prg: limits.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > limits.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/limits.out
$(DIFF) limits.out limits.ref $(DIFF) $(WORKDIR)/limits.out limits.ref
# the rest are tests that fail currently for one reason or another # the rest are tests that fail currently for one reason or another
fields%prg: fields.c $(WORKDIR)/fields%prg: fields.c
@echo "FIXME: " $@ "will currently fail" @echo "FIXME: " $@ "will currently fail"
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
-$(SIM65) $(SIM65FLAGS) $@ -$(SIM65) $(SIM65FLAGS) $@
sitest%prg: sitest.c $(WORKDIR)/sitest%prg: sitest.c
@echo "FIXME: " $@ "will currently fail" @echo "FIXME: " $@ "will currently fail"
-$(CL65) $(CC65FLAGS) $< -o $@ -$(CL65) $(CC65FLAGS) $< -o $@
-$(SIM65) $(SIM65FLAGS) $@ -$(SIM65) $(SIM65FLAGS) $@
clean: clean:
@$(RM) *.o @$(RM) $(TESTS)
@$(RM) *.prg @$(RM) $(patsubst %.c,$(WORKDIR)/%.o,$(wildcard *.c))
@$(RM) *.out @$(RM) $(patsubst %.c,$(WORKDIR)/%.out,$(wildcard *.c))

View File

@ -26,66 +26,66 @@ CFLAGS := -O2 -Wall -W -Wextra -fwrapv -fno-strict-overflow
.PHONY: all clean .PHONY: all clean
REFS := $(patsubst %.c,%.ref,$(wildcard *.c)) REFS := $(patsubst %.c,$(WORKDIR)/%.ref,$(wildcard *.c))
TESTS := $(patsubst %.c,%.prg,$(wildcard *.c)) TESTS := $(patsubst %.c,$(WORKDIR)/%.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.o.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.o.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.os.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.os.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.or.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.or.prg,$(wildcard *.c))
all: $(REFS) $(TESTS) all: $(REFS) $(TESTS)
%.ref: %.c $(WORKDIR)/%.ref: %.c
$(CC) $(CFLAGS) $< -o $*.host $(CC) $(CFLAGS) $< -o $(WORKDIR)/$*.host
./$*.host > $@ $(WORKDIR)/$*.host > $@
%.prg: %.c %.ref $(WORKDIR)/%.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.o.prg: %.c %.ref $(WORKDIR)/%.o.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.os.prg: %.c %.ref $(WORKDIR)/%.os.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.osi.prg: %.c %.ref $(WORKDIR)/%.osi.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.osir.prg: %.c %.ref $(WORKDIR)/%.osir.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.oi.prg: %.c %.ref $(WORKDIR)/%.oi.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.oir.prg: %.c %.ref $(WORKDIR)/%.oir.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
%.or.prg: %.c %.ref $(WORKDIR)/%.or.prg: %.c $(WORKDIR)/%.ref
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ > $*.out $(SIM65) $(SIM65FLAGS) $@ > $(WORKDIR)/$*.out
$(DIFF) $*.out $*.ref $(DIFF) $(WORKDIR)/$*.out $(WORKDIR)/$*.ref
clean: clean:
@$(RM) *.o @$(RM) $(TESTS)
@$(RM) *.prg @$(RM) $(patsubst %.c,$(WORKDIR)/%.o,$(wildcard *.c))
@$(RM) *.out @$(RM) $(patsubst %.c,$(WORKDIR)/%.out,$(wildcard *.c))
@$(RM) *.ref @$(RM) $(patsubst %.c,$(WORKDIR)/%.ref,$(wildcard *.c))
@$(RM) *.host @$(RM) $(patsubst %.c,$(WORKDIR)/%.host,$(wildcard *.c))

View File

@ -21,49 +21,49 @@ WORKDIR := ./../../testwrk
.PHONY: all clean .PHONY: all clean
TESTS := $(patsubst %.c,%.prg,$(wildcard *.c)) TESTS := $(patsubst %.c,$(WORKDIR)/%.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.o.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.o.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.os.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.os.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.osir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.osir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oi.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oi.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.oir.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.oir.prg,$(wildcard *.c))
TESTS += $(patsubst %.c,%.or.prg,$(wildcard *.c)) TESTS += $(patsubst %.c,$(WORKDIR)/%.or.prg,$(wildcard *.c))
all: $(TESTS) all: $(TESTS)
%.prg: %.c $(WORKDIR)/%.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.o.prg: %.c $(WORKDIR)/%.o.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.os.prg: %.c $(WORKDIR)/%.os.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.osi.prg: %.c $(WORKDIR)/%.osi.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.osir.prg: %.c $(WORKDIR)/%.osir.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.oi.prg: %.c $(WORKDIR)/%.oi.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.oir.prg: %.c $(WORKDIR)/%.oir.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
%.or.prg: %.c $(WORKDIR)/%.or.prg: %.c
$(CL65) $(CC65FLAGS) $< -o $@ $(CL65) $(CC65FLAGS) $< -o $@
$(SIM65) $(SIM65FLAGS) $@ $(SIM65) $(SIM65FLAGS) $@
clean: clean:
@$(RM) *.o @$(RM) $(TESTS)
@$(RM) *.prg @$(RM) $(patsubst %.c,$(WORKDIR)/%.o,$(wildcard *.c))