From 7edfc16f2586b11245626b7de5679884fd04df1e Mon Sep 17 00:00:00 2001 From: Gary Talent Date: Tue, 14 Jan 2020 20:38:26 -0600 Subject: [PATCH] [nostalgia] Make Makefile more portable --- Makefile | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/Makefile b/Makefile index b875837e..b5398872 100644 --- a/Makefile +++ b/Makefile @@ -3,17 +3,18 @@ HOST_ENV=${OS}-$(shell uname -m) DEVENV=devenv$(shell pwd | sed 's/\//-/g') DEVENV_IMAGE=nostalgia-devenv CURRENT_BUILD=$(file < .current_build) -ifneq ($(shell which gmake 2> /dev/null),) - MAKE=gmake -s -else - MAKE=make -s -endif ifneq ($(shell which docker 2> /dev/null),) ifeq ($(shell docker inspect --format="{{.State.Status}}" ${DEVENV} 2>&1),running) ENV_RUN=docker exec -i -t --user $(shell id -u ${USER}) ${DEVENV} endif endif +ifeq ($(OS),windows) + RM_RF=Remove-Item -ErrorAction Ignore -Path -Recurse +else + RM_RF=rm -rf +endif + ifeq ($(OS),darwin) NOSTALGIA_STUDIO=./dist/${CURRENT_BUILD}/nostalgia-studio.app/Contents/MacOS/nostalgia-studio NOSTALGIA_STUDIO_PROFILE=dist/${CURRENT_BUILD}/nostalgia-studio.app/Contents/Resources/nostalgia-studio.json @@ -39,7 +40,7 @@ clean: $(foreach file, $(wildcard build/*), cmake --build $(file) --target clean;) .PHONY: purge purge: - ${ENV_RUN} rm -rf build .current_build + ${ENV_RUN} ${RM_RF} build .current_build .PHONY: test test: $(foreach file, $(wildcard build/*), cmake --build $(file) --target test;) @@ -89,25 +90,25 @@ conan: .PHONY: configure-release configure-release: - ${ENV_RUN} rm -rf build/${HOST_ENV}-release + ${ENV_RUN} ${RM_RF} build/${HOST_ENV}-release ${ENV_RUN} ./scripts/setup-build ${HOST_ENV} release .PHONY: configure-debug configure-debug: - ${ENV_RUN} rm -rf build/${HOST_ENV}-debug + ${ENV_RUN} ${RM_RF} build/${HOST_ENV}-debug ${ENV_RUN} ./scripts/setup-build ${HOST_ENV} debug .PHONY: configure-asan configure-asan: - ${ENV_RUN} rm -rf build/${HOST_ENV}-asan + ${ENV_RUN} ${RM_RF} build/${HOST_ENV}-asan ${ENV_RUN} ./scripts/setup-build ${HOST_ENV} asan .PHONY: configure-gba configure-gba: - ${ENV_RUN} rm -rf build/gba-release + ${ENV_RUN} ${RM_RF} build/gba-release ${ENV_RUN} ./scripts/setup-build gba release .PHONY: configure-gba-debug configure-gba-debug: - ${ENV_RUN} rm -rf build/gba-debug + ${ENV_RUN} ${RM_RF} build/gba-debug ${ENV_RUN} ./scripts/setup-build gba debug