2017-03-19 16:48:12 +00:00
|
|
|
# Makefile for the regression tests that generate output which has to be
|
2014-11-22 17:28:05 +00:00
|
|
|
# compared with reference output
|
|
|
|
|
2014-11-23 11:18:19 +00:00
|
|
|
ifneq ($(shell echo),)
|
2017-03-19 16:48:12 +00:00
|
|
|
CMD_EXE = 1
|
2014-11-23 11:18:19 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifdef CMD_EXE
|
2017-03-19 16:48:12 +00:00
|
|
|
S = $(subst /,\,/)
|
|
|
|
EXE = .exe
|
2017-03-20 10:22:04 +00:00
|
|
|
NULLDEV = nul:
|
2017-03-19 16:48:12 +00:00
|
|
|
MKDIR = mkdir $(subst /,\,$1)
|
|
|
|
RMDIR = -rmdir /s /q $(subst /,\,$1)
|
2022-11-11 19:54:38 +00:00
|
|
|
COPY = copy $(subst /,\,$1) $(subst /,\,$2)
|
2014-11-23 11:18:19 +00:00
|
|
|
else
|
2017-03-19 16:48:12 +00:00
|
|
|
S = /
|
|
|
|
EXE =
|
2017-03-20 10:22:04 +00:00
|
|
|
NULLDEV = /dev/null
|
2017-03-19 16:48:12 +00:00
|
|
|
MKDIR = mkdir -p $1
|
|
|
|
RMDIR = $(RM) -r $1
|
2022-11-11 19:54:38 +00:00
|
|
|
COPY = cp $1 $2
|
2014-11-23 11:18:19 +00:00
|
|
|
endif
|
2014-11-22 18:45:40 +00:00
|
|
|
|
2017-03-20 10:22:04 +00:00
|
|
|
ifdef QUIET
|
|
|
|
.SILENT:
|
|
|
|
NULLERR = 2>$(NULLDEV)
|
|
|
|
endif
|
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
SIM65FLAGS = -x 200000000
|
2015-06-26 22:03:45 +00:00
|
|
|
|
2020-08-26 18:37:28 +00:00
|
|
|
CC65 := $(if $(wildcard ../../bin/cc65*),..$S..$Sbin$Scc65,cc65)
|
|
|
|
CA65 := $(if $(wildcard ../../bin/ca65*),..$S..$Sbin$Sca65,ca65)
|
|
|
|
LD65 := $(if $(wildcard ../../bin/ld65*),..$S..$Sbin$Sld65,ld65)
|
2015-06-26 22:03:45 +00:00
|
|
|
SIM65 := $(if $(wildcard ../../bin/sim65*),..$S..$Sbin$Ssim65,sim65)
|
2014-11-25 11:56:45 +00:00
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
WORKDIR = ..$S..$Stestwrk$Sref
|
2014-11-24 19:57:58 +00:00
|
|
|
|
2017-06-07 14:26:34 +00:00
|
|
|
OPTIONS = g O Os Osi Osir Osr Oi Oir Or
|
2017-03-19 16:48:12 +00:00
|
|
|
|
2020-11-17 18:40:36 +00:00
|
|
|
ISEQUAL = ..$S..$Stestwrk$Sisequal$(EXE)
|
2017-03-19 16:48:12 +00:00
|
|
|
|
2023-12-10 22:18:55 +00:00
|
|
|
# NOTE: the current test bench may include K&R style C, C89 style C, C99 - and
|
|
|
|
# even things from later standards. Technically C99 removed certain C89
|
|
|
|
# constructs - However, so far GCC would still compile them and issue a
|
|
|
|
# warning (instead of an error). Now, GCC 14 will be more strict about this,
|
|
|
|
# and by default make those things an error instead. We use -std=gnu17 here
|
|
|
|
# so we can still build the references with a modern compiler, and don't
|
|
|
|
# have to deal with special-casing individual tests that use constructs
|
|
|
|
# from those old standards. Should this become a problem in the future, we
|
|
|
|
# will have to change that, and create said special cases here.
|
|
|
|
# see discussion in https://github.com/cc65/cc65/issues/2277
|
2017-03-19 16:48:12 +00:00
|
|
|
CC = gcc
|
2023-12-10 22:18:55 +00:00
|
|
|
CFLAGS = -std=gnu17 -O2 -Wall -W -Wextra -funsigned-char -fwrapv -fno-strict-overflow
|
2014-11-22 17:28:05 +00:00
|
|
|
|
2014-11-23 11:18:19 +00:00
|
|
|
.PHONY: all clean
|
2014-11-22 17:28:05 +00:00
|
|
|
|
2022-11-03 16:40:13 +00:00
|
|
|
# list of sources that produces warnings that we want to check. a .cref file
|
|
|
|
# containing the exact output is required.
|
|
|
|
CUSTOMSOURCES = \
|
|
|
|
custom-reference.c
|
|
|
|
|
|
|
|
# list of sources that produce a compiler error. a .cref files containing the
|
|
|
|
# exact error output is required
|
|
|
|
ERRORSOURCES = \
|
2022-11-11 20:22:20 +00:00
|
|
|
custom-reference-error.c \
|
|
|
|
bug1889-missing-identifier.c
|
2022-11-03 16:40:13 +00:00
|
|
|
|
|
|
|
SOURCES := $(filter-out $(CUSTOMSOURCES) $(ERRORSOURCES),$(wildcard *.c))
|
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
REFS = $(SOURCES:%.c=$(WORKDIR)/%.ref)
|
2022-11-03 16:40:13 +00:00
|
|
|
CUSTOMREFS = $(CUSTOMSOURCES:%.c=$(WORKDIR)/%.cref) $(ERRORSOURCES:%.c=$(WORKDIR)/%.cref)
|
|
|
|
|
2017-03-19 19:07:19 +00:00
|
|
|
TESTS = $(foreach option,$(OPTIONS),$(SOURCES:%.c=$(WORKDIR)/%.$(option).6502.prg))
|
|
|
|
TESTS += $(foreach option,$(OPTIONS),$(SOURCES:%.c=$(WORKDIR)/%.$(option).65c02.prg))
|
2014-11-22 17:28:05 +00:00
|
|
|
|
2022-11-03 16:40:13 +00:00
|
|
|
CUSTOMTESTS = $(foreach option,$(OPTIONS),$(CUSTOMSOURCES:%.c=$(WORKDIR)/%.$(option).6502.custom.prg))
|
|
|
|
CUSTOMTESTS += $(foreach option,$(OPTIONS),$(CUSTOMSOURCES:%.c=$(WORKDIR)/%.$(option).65c02.custom.prg))
|
|
|
|
|
|
|
|
ERRORTESTS = $(foreach option,$(OPTIONS),$(ERRORSOURCES:%.c=$(WORKDIR)/%.$(option).6502.error.prg))
|
|
|
|
ERRORTESTS += $(foreach option,$(OPTIONS),$(ERRORSOURCES:%.c=$(WORKDIR)/%.$(option).65c02.error.prg))
|
|
|
|
|
|
|
|
all: $(CUSTOMREFS) $(REFS) $(TESTS) $(CUSTOMTESTS) $(ERRORTESTS)
|
2014-11-22 18:45:40 +00:00
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
$(WORKDIR):
|
|
|
|
$(call MKDIR,$(WORKDIR))
|
2017-03-01 11:29:53 +00:00
|
|
|
|
2022-11-03 16:40:13 +00:00
|
|
|
$(ISEQUAL): ../isequal.c | $(WORKDIR)
|
|
|
|
$(CC) $(CFLAGS) -o $@ $<
|
|
|
|
|
|
|
|
$(WORKDIR)/%.cref: %.cref | $(WORKDIR)
|
|
|
|
$(if $(QUIET),echo ref/$*.cref)
|
2022-11-11 19:54:38 +00:00
|
|
|
$(call COPY,$*.cref,$@)
|
2022-11-03 16:40:13 +00:00
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
$(WORKDIR)/%.ref: %.c | $(WORKDIR)
|
2017-03-20 10:22:04 +00:00
|
|
|
$(if $(QUIET),echo ref/$*.host)
|
2020-06-25 06:54:58 +00:00
|
|
|
$(CC) $(CFLAGS) -o $(WORKDIR)/$*.host $< $(NULLERR)
|
2015-06-26 22:03:45 +00:00
|
|
|
$(WORKDIR)$S$*.host > $@
|
2014-11-22 17:28:05 +00:00
|
|
|
|
2017-03-19 16:48:12 +00:00
|
|
|
# "yaccdbg.c" includes "yacc.c".
|
|
|
|
# yaccdbg's built files must depend on both of them.
|
|
|
|
#
|
|
|
|
$(WORKDIR)/yaccdbg.ref: yacc.c
|
|
|
|
$(WORKDIR)/yaccdbg.%.prg: yacc.c
|
|
|
|
|
|
|
|
define PRG_template
|
|
|
|
|
2020-08-26 18:37:28 +00:00
|
|
|
$(WORKDIR)/%.$1.$2.prg: %.c $(WORKDIR)/%.ref $(ISEQUAL)
|
2017-03-20 10:22:04 +00:00
|
|
|
$(if $(QUIET),echo ref/$$*.$1.$2.prg)
|
2020-08-26 18:37:28 +00:00
|
|
|
$(CC65) -t sim$2 $$(CC65FLAGS) -$1 -o $$(@:.prg=.s) $$< $(NULLERR)
|
|
|
|
$(CA65) -t sim$2 -o $$(@:.prg=.o) $$(@:.prg=.s) $(NULLERR)
|
|
|
|
$(LD65) -t sim$2 -o $$@ $$(@:.prg=.o) sim$2.lib $(NULLERR)
|
2020-06-27 19:15:22 +00:00
|
|
|
$(SIM65) $(SIM65FLAGS) $$@ > $(WORKDIR)/$$*.$1.$2.out
|
2020-08-26 18:37:28 +00:00
|
|
|
$(ISEQUAL) $(WORKDIR)/$$*.$1.$2.out $(WORKDIR)/$$*.ref
|
2017-03-19 16:48:12 +00:00
|
|
|
|
|
|
|
endef # PRG_template
|
|
|
|
|
2022-11-03 16:40:13 +00:00
|
|
|
# extra template for the case when compilation works, but we still want to
|
|
|
|
# compare the warning output with our custom reference
|
|
|
|
define PRG_custom_template
|
|
|
|
|
|
|
|
$(WORKDIR)/%.$1.$2.custom.prg: %.c $(WORKDIR)/%.ref %.c $(WORKDIR)/%.cref $(ISEQUAL)
|
|
|
|
$(if $(QUIET),echo cref/$$*.$1.$2.custom.prg)
|
|
|
|
-$(CC65) -t sim$2 $$(CC65FLAGS) -$1 -o $$(@:.custom.prg=.s) $$< 2> $(WORKDIR)/$$*.$1.$2.cout
|
|
|
|
$(CA65) -t sim$2 -o $$(@:.custom.prg=.o) $$(@:.custom.prg=.s) $(NULLERR)
|
|
|
|
$(LD65) -t sim$2 -o $$@ $$(@:.custom.prg=.o) sim$2.lib $(NULLERR)
|
|
|
|
$(SIM65) $(SIM65FLAGS) $$@ > $(WORKDIR)/$$*.$1.$2.out
|
|
|
|
$(ISEQUAL) $(WORKDIR)/$$*.$1.$2.cout $(WORKDIR)/$$*.cref
|
|
|
|
$(ISEQUAL) $(WORKDIR)/$$*.$1.$2.out $(WORKDIR)/$$*.ref
|
|
|
|
|
|
|
|
endef # PRG_error_template
|
|
|
|
|
|
|
|
# extra template for the case when compilation fails, but we still want to
|
|
|
|
# compare the error output with our custom reference
|
|
|
|
define PRG_error_template
|
|
|
|
|
|
|
|
$(WORKDIR)/%.$1.$2.error.prg: %.c $(WORKDIR)/%.cref $(ISEQUAL)
|
|
|
|
$(if $(QUIET),echo cref/$$*.$1.$2.error.prg)
|
|
|
|
-$(CC65) -t sim$2 $$(CC65FLAGS) -$1 -o $$(@:.error.prg=.s) $$< 2> $(WORKDIR)/$$*.$1.$2.cout
|
|
|
|
# $(CA65) -t sim$2 -o $$(@:.error.prg=.o) $$(@:.error.prg=.s) $(NULLERR)
|
|
|
|
# $(LD65) -t sim$2 -o $$@ $$(@:.error.prg=.o) sim$2.lib $(NULLERR)
|
|
|
|
# $(SIM65) $(SIM65FLAGS) $$@ > $(WORKDIR)/$$*.$1.$2.out
|
|
|
|
$(ISEQUAL) $(WORKDIR)/$$*.$1.$2.cout $(WORKDIR)/$$*.cref
|
|
|
|
|
|
|
|
endef # PRG_error_template
|
|
|
|
|
2017-03-19 19:07:19 +00:00
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_template,$(option),6502)))
|
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_template,$(option),65c02)))
|
2014-11-22 17:28:05 +00:00
|
|
|
|
2022-11-03 16:40:13 +00:00
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_custom_template,$(option),6502)))
|
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_custom_template,$(option),65c02)))
|
|
|
|
|
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_error_template,$(option),6502)))
|
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_error_template,$(option),65c02)))
|
|
|
|
|
2014-11-22 17:28:05 +00:00
|
|
|
clean:
|
2017-03-19 16:48:12 +00:00
|
|
|
@$(call RMDIR,$(WORKDIR))
|