3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-04 13:54:07 +00:00
sby/tests/Makefile

57 lines
1.3 KiB
Makefile

test:
.PHONY: test clean refresh help
OS_NAME := $(shell python3 -c "import os;print(os.name)")
ifeq (nt,$(OS_NAME))
ifeq (quoted,$(shell echo "quoted"))
OS_NAME := nt-unix-like
endif
endif
ifeq (nt,$(OS_NAME))
$(error This Makefile requires unix-like tools and shell, e.g. MSYS2.)
endif
help:
@cat make/help.txt
export SBY_WORKDIR_GITIGNORE := 1
ifeq ($(SBY_CMD),)
SBY_MAIN := $(realpath $(dir $(firstword $(MAKEFILE_LIST)))/../sbysrc/sby.py)
else
SBY_MAIN := $(realpath $(dir $(firstword $(MAKEFILE_LIST)))/make/run_sby.py)
endif
ifeq (nt-unix-like,$(OS_NAME))
SBY_MAIN := $(shell cygpath -w $(SBY_MAIN))
endif
export SBY_MAIN
make/rules/collect.mk: make/collect_tests.py
python3 make/collect_tests.py
make/rules/test/%.mk:
python3 make/test_rules.py $<
ifneq (help,$(MAKECMDGOALS))
# This should run every time but only trigger anything depending on it whenever
# the script overwrites make/rules/found_tools. This doesn't really match how
# make targets usually work, so we manually shell out here.
FIND_TOOLS := $(shell python3 make/required_tools.py || echo error)
ifneq (,$(findstring error,$(FIND_TOOLS)))
$(error could not run 'python3 make/required_tools.py')
endif
ifneq (,$(FIND_TOOLS))
$(warning $(FIND_TOOLS))
endif
include make/rules/collect.mk
endif