mirror of
https://github.com/cc65/cc65.git
synced 2024-11-18 00:07:21 +00:00
c658acbf85
cl65 creates intermediate files based on the source file name in the source file directory. Calling cl65 in parallel with the same source file causes those intermediate files to get overwritten. Fixes #1080
86 lines
2.2 KiB
Makefile
86 lines
2.2 KiB
Makefile
# Makefile for the regression tests that generate output which has to be
|
|
# compared with reference output
|
|
|
|
ifneq ($(shell echo),)
|
|
CMD_EXE = 1
|
|
endif
|
|
|
|
ifdef CMD_EXE
|
|
S = $(subst /,\,/)
|
|
EXE = .exe
|
|
NULLDEV = nul:
|
|
MKDIR = mkdir $(subst /,\,$1)
|
|
RMDIR = -rmdir /s /q $(subst /,\,$1)
|
|
else
|
|
S = /
|
|
EXE =
|
|
NULLDEV = /dev/null
|
|
MKDIR = mkdir -p $1
|
|
RMDIR = $(RM) -r $1
|
|
endif
|
|
|
|
ifdef QUIET
|
|
.SILENT:
|
|
NULLERR = 2>$(NULLDEV)
|
|
endif
|
|
|
|
SIM65FLAGS = -x 200000000
|
|
|
|
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)
|
|
SIM65 := $(if $(wildcard ../../bin/sim65*),..$S..$Sbin$Ssim65,sim65)
|
|
|
|
WORKDIR = ..$S..$Stestwrk$Sref
|
|
|
|
OPTIONS = g O Os Osi Osir Osr Oi Oir Or
|
|
|
|
ISEQUAL = $(WORKDIR)$Sisequal$(EXE)
|
|
|
|
CC = gcc
|
|
CFLAGS = -O2 -Wall -W -Wextra -funsigned-char -fwrapv -fno-strict-overflow
|
|
|
|
.PHONY: all clean
|
|
|
|
SOURCES := $(wildcard *.c)
|
|
REFS = $(SOURCES:%.c=$(WORKDIR)/%.ref)
|
|
TESTS = $(foreach option,$(OPTIONS),$(SOURCES:%.c=$(WORKDIR)/%.$(option).6502.prg))
|
|
TESTS += $(foreach option,$(OPTIONS),$(SOURCES:%.c=$(WORKDIR)/%.$(option).65c02.prg))
|
|
|
|
all: $(REFS) $(TESTS)
|
|
|
|
$(WORKDIR):
|
|
$(call MKDIR,$(WORKDIR))
|
|
|
|
$(WORKDIR)/%.ref: %.c | $(WORKDIR)
|
|
$(if $(QUIET),echo ref/$*.host)
|
|
$(CC) $(CFLAGS) -o $(WORKDIR)/$*.host $< $(NULLERR)
|
|
$(WORKDIR)$S$*.host > $@
|
|
|
|
$(ISEQUAL): ../isequal.c | $(WORKDIR)
|
|
$(CC) $(CFLAGS) -o $@ $<
|
|
|
|
# "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
|
|
|
|
$(WORKDIR)/%.$1.$2.prg: %.c $(WORKDIR)/%.ref $(ISEQUAL)
|
|
$(if $(QUIET),echo ref/$$*.$1.$2.prg)
|
|
$(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)
|
|
$(SIM65) $(SIM65FLAGS) $$@ > $(WORKDIR)/$$*.$1.$2.out
|
|
$(ISEQUAL) $(WORKDIR)/$$*.$1.$2.out $(WORKDIR)/$$*.ref
|
|
|
|
endef # PRG_template
|
|
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_template,$(option),6502)))
|
|
$(foreach option,$(OPTIONS),$(eval $(call PRG_template,$(option),65c02)))
|
|
|
|
clean:
|
|
@$(call RMDIR,$(WORKDIR))
|