X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=Makefile;h=3e5877f063d467b511c5bcff015b9361542789a4;hp=c944d58b08a3916d02918d7a18a26c275f186f4f;hb=67f3bfab902e53e0dc24a01eb6c0e4d274030a47;hpb=cb5d2ce15259a2aea0626cfc81733563074ea591 diff --git a/Makefile b/Makefile index c944d58b..3e5877f0 100644 --- a/Makefile +++ b/Makefile @@ -4,7 +4,7 @@ # (c) 1995-2015 by Artsoft Entertainment # Holger Schemel # info@artsoft.org -# http://www.artsoft.org/ +# https://www.artsoft.org/ # ----------------------------------------------------------------------------- # Makefile # ============================================================================= @@ -22,29 +22,25 @@ CC = gcc MAKE = make # directory for read-only game data (like graphics, sounds, levels) +# (this directory is usually the game's installation directory) # default is '.' to be able to run program without installation -# RO_GAME_DIR = /usr/games +# RO_GAME_DIR = . # use the following setting for Debian / Ubuntu installations: # RO_GAME_DIR = /usr/share/games/rocksndiamonds # directory for writable game data (like highscore files) +# (if no "scores" directory exists, scores are saved in user data directory) # default is '.' to be able to run program without installation -# RW_GAME_DIR = /var/games +# RW_GAME_DIR = . # use the following setting for Debian / Ubuntu installations: # RW_GAME_DIR = /var/games/rocksndiamonds # uncomment if system has no joystick include file # JOYSTICK = -DNO_JOYSTICK -# choose if more than one global score file entry for one player is allowed -# (default: MANY_PER_NAME) -# uncomment to install game in multi-user environment -# SCORE_ENTRIES = ONE_PER_NAME -# uncomment to install game in single-user environment (default) -# SCORE_ENTRIES = MANY_PER_NAME - # path for cross-compiling (only needed for non-native Windows build) -CROSS_PATH_WIN32 = /usr/local/cross-tools/i386-mingw32msvc +CROSS_PATH_WIN32 = /usr/local/cross-tools/i686-w64-mingw32 +CROSS_PATH_WIN64 = /usr/local/cross-tools/x86_64-w64-mingw32 # ----------------------------------------------------------------------------- @@ -54,7 +50,10 @@ CROSS_PATH_WIN32 = /usr/local/cross-tools/i386-mingw32msvc .EXPORT_ALL_VARIABLES: SRC_DIR = src +ANDROID_DIR ?= build-projects/android + MAKE_CMD = $(MAKE) -C $(SRC_DIR) +MAKE_CMD_ANDROID = $(MAKE) -C $(ANDROID_DIR) # ----------------------------------------------------------------------------- @@ -64,20 +63,22 @@ MAKE_CMD = $(MAKE) -C $(SRC_DIR) all: @$(MAKE_CMD) -sdl: - @$(MAKE_CMD) TARGET=sdl +cross-win32: + @PATH=$(CROSS_PATH_WIN32)/bin:${PATH} $(MAKE_CMD) PLATFORM=cross-win32 -sdl2: - @$(MAKE_CMD) TARGET=sdl2 +cross-win64: + @PATH=$(CROSS_PATH_WIN64)/bin:${PATH} $(MAKE_CMD) PLATFORM=cross-win64 -mac: - @$(MAKE_CMD) PLATFORM=macosx +android-prepare: + @$(MAKE_CMD_ANDROID) prepare -cross-win32: - @PATH=$(CROSS_PATH_WIN32)/bin:${PATH} $(MAKE_CMD) PLATFORM=cross-win32 +android-package: + @$(MAKE_CMD_ANDROID) package -strip: - @$(MAKE_CMD) strip +android-clean: + @$(MAKE_CMD_ANDROID) clean + +android: android-package clean: @$(MAKE_CMD) clean @@ -85,14 +86,25 @@ clean: clean-git: @$(MAKE_CMD) clean-git +clean-android: android-clean + # ----------------------------------------------------------------------------- -# development, test, distribution build and packaging targets +# development targets # ----------------------------------------------------------------------------- +MAKE_ENGINETEST = ./Scripts/make_enginetest.sh +MAKE_LEVELSKETCH = ./Scripts/make_levelsketch_images.sh + auto-conf: @$(MAKE_CMD) auto-conf +conf-time: + @$(MAKE_CMD) conf-time + +conf-hash: + @$(MAKE_CMD) conf-hash + run: all @$(MAKE_CMD) run @@ -102,70 +114,130 @@ gdb: all valgrind: all @$(MAKE_CMD) valgrind +tags: + $(MAKE_CMD) tags + +depend dep: + $(MAKE_CMD) depend + enginetest: all - ./Scripts/make_enginetest.sh + $(MAKE_ENGINETEST) enginetestcustom: all - ./Scripts/make_enginetest.sh custom + $(MAKE_ENGINETEST) custom enginetestfast: all - ./Scripts/make_enginetest.sh fast + $(MAKE_ENGINETEST) fast enginetestnew: all - ./Scripts/make_enginetest.sh new + $(MAKE_ENGINETEST) new leveltest: all - ./Scripts/make_enginetest.sh leveltest + $(MAKE_ENGINETEST) leveltest levelsketch_images: all - ./Scripts/make_levelsketch_images.sh + $(MAKE_LEVELSKETCH) + + +# ----------------------------------------------------------------------------- +# distribution targets +# ----------------------------------------------------------------------------- + +MAKE_DIST = ./Scripts/make_dist.sh dist-clean: @$(MAKE_CMD) dist-clean -dist-build-unix: +dist-clean-android: + @$(MAKE_CMD_ANDROID) dist-clean + +dist-build-linux: @BUILD_DIST=TRUE $(MAKE) dist-build-win32: @BUILD_DIST=TRUE $(MAKE) cross-win32 -dist-build-macosx: +dist-build-win64: + @BUILD_DIST=TRUE $(MAKE) cross-win64 + +dist-build-mac: @BUILD_DIST=TRUE $(MAKE) -dist-package-unix: - ./Scripts/make_dist.sh package unix +dist-build-android: + @BUILD_DIST=TRUE $(MAKE) android + +dist-package-linux: + $(MAKE_DIST) package linux dist-package-win32: - ./Scripts/make_dist.sh package win + $(MAKE_DIST) package win32 + +dist-package-win64: + $(MAKE_DIST) package win64 + +dist-package-mac: + $(MAKE_DIST) package mac + +dist-package-android: + $(MAKE_DIST) package android + +dist-copy-package-linux: + $(MAKE_DIST) copy-package linux + +dist-copy-package-win32: + $(MAKE_DIST) copy-package win32 + +dist-copy-package-win64: + $(MAKE_DIST) copy-package win64 + +dist-copy-package-mac: + $(MAKE_DIST) copy-package mac -dist-package-macosx: - ./Scripts/make_dist.sh package mac +dist-copy-package-android: + $(MAKE_DIST) copy-package android -dist-upload-unix: - ./Scripts/make_dist.sh upload unix +dist-upload-linux: + $(MAKE_DIST) upload linux dist-upload-win32: - ./Scripts/make_dist.sh upload win + $(MAKE_DIST) upload win32 -dist-upload-macosx: - ./Scripts/make_dist.sh upload mac +dist-upload-win64: + $(MAKE_DIST) upload win64 + +dist-upload-mac: + $(MAKE_DIST) upload mac + +dist-upload-android: + $(MAKE_DIST) upload android dist-package-all: - $(MAKE) dist-package-unix + $(MAKE) dist-package-linux $(MAKE) dist-package-win32 - $(MAKE) dist-package-macosx + $(MAKE) dist-package-win64 + $(MAKE) dist-package-mac + $(MAKE) dist-package-android + +dist-copy-package-all: + $(MAKE) dist-copy-package-linux + $(MAKE) dist-copy-package-win32 + $(MAKE) dist-copy-package-win64 + $(MAKE) dist-copy-package-mac + $(MAKE) dist-copy-package-android dist-upload-all: - $(MAKE) dist-upload-unix + $(MAKE) dist-upload-linux $(MAKE) dist-upload-win32 - $(MAKE) dist-upload-macosx + $(MAKE) dist-upload-win64 + $(MAKE) dist-upload-mac + $(MAKE) dist-upload-android + +dist-release-all: dist-package-all dist-copy-package-all dist-upload-all package-all: dist-package-all -upload-all: dist-upload-all +copy-package-all: dist-copy-package-all -tags: - $(MAKE_CMD) tags +upload-all: dist-upload-all -depend dep: - $(MAKE_CMD) depend +release-all: dist-release-all