added optional button to restart game (door, panel and touch variants)
[rocksndiamonds.git] / Makefile
index 41840b0cb6e2734dd816b2dd57051631069f5bfa..a821304008dc5a51a27c376f8fcef6e44a740612 100644 (file)
--- 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
 # =============================================================================
@@ -21,30 +21,19 @@ CC = gcc
 # (this must be set to "gmake" for some systems)
 MAKE = make
 
-# directory for read-only game data (like graphics, sounds, levels)
+# 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
+# BASE_PATH = .
 # use the following setting for Debian / Ubuntu installations:
-# RO_GAME_DIR = /usr/share/games/rocksndiamonds
-
-# directory for writable game data (like highscore files)
-# default is '.' to be able to run program without installation
-# RW_GAME_DIR = /var/games
-# use the following setting for Debian / Ubuntu installations:
-# RW_GAME_DIR = /var/games/rocksndiamonds
+# BASE_PATH = /usr/share/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 +43,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,17 +56,25 @@ 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
+
+android-clean:
+       @$(MAKE_CMD_ANDROID) clean
+
+android: android-package
+
+emscripten:
+       @emmake $(MAKE_CMD) PLATFORM=emscripten
 
 clean:
        @$(MAKE_CMD) clean
@@ -82,14 +82,25 @@ clean:
 clean-git:
        @$(MAKE_CMD) clean-git
 
+clean-android: android-clean
+
 
 # -----------------------------------------------------------------------------
-# development, test, distribution build and packaging targets
+# development targets
 # -----------------------------------------------------------------------------
 
+MAKE_ENGINETEST = ./tests/enginetest/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
 
@@ -99,70 +110,141 @@ gdb: all
 valgrind: all
        @$(MAKE_CMD) valgrind
 
-enginetest: all
-       ./Scripts/make_enginetest.sh
+tags:
+       $(MAKE_CMD) tags
 
-enginetestcustom: all
-       ./Scripts/make_enginetest.sh custom
+depend dep:
+       $(MAKE_CMD) depend
 
-enginetestfast: all
-       ./Scripts/make_enginetest.sh fast
+enginetest: all
+       $(MAKE_ENGINETEST)
 
-enginetestnew: all
-       ./Scripts/make_enginetest.sh new
+levelsketch_images: all
+       $(MAKE_LEVELSKETCH)
 
-leveltest: all
-       ./Scripts/make_enginetest.sh leveltest
 
-levelsketch_images: all
-       ./Scripts/make_levelsketch_images.sh
+# -----------------------------------------------------------------------------
+# 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-build-emscripten:
+       @BUILD_DIST=TRUE $(MAKE) emscripten
+
+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-package-emscripten:
+       $(MAKE_DIST) package emscripten
+
+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-copy-package-emscripten:
+       $(MAKE_DIST) copy-package emscripten
+
+dist-upload-linux:
+       $(MAKE_DIST) upload linux
 
 dist-upload-win32:
-       ./Scripts/make_dist.sh upload win
+       $(MAKE_DIST) upload win32
+
+dist-upload-win64:
+       $(MAKE_DIST) upload win64
+
+dist-upload-mac:
+       $(MAKE_DIST) upload mac
 
-dist-upload-macosx:
-       ./Scripts/make_dist.sh upload mac
+dist-upload-android:
+       $(MAKE_DIST) upload android
+
+dist-upload-emscripten:
+       $(MAKE_DIST) upload emscripten
+
+dist-deploy-emscripten:
+       $(MAKE_DIST) deploy emscripten
 
 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
+       $(MAKE) dist-package-emscripten
+
+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
+       $(MAKE) dist-copy-package-emscripten
 
 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
+       $(MAKE) dist-upload-emscripten
+
+dist-deploy-all:
+       $(MAKE) dist-deploy-emscripten
+
+dist-release-all: dist-package-all dist-copy-package-all dist-upload-all dist-deploy-all
 
 package-all: dist-package-all
 
+copy-package-all: dist-copy-package-all
+
 upload-all: dist-upload-all
 
-tags:
-       $(MAKE_CMD) tags
+deploy-all: dist-deploy-all
 
-depend dep:
-       $(MAKE_CMD) depend
+release-all: dist-release-all