forked from cory/tildefriends
		
	I think I made all build types conditional on having the appropriate build tools available, and make all make everything currently possible.
git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4531 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
		
							
								
								
									
										48
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								Makefile
									
									
									
									
									
								
							@@ -11,12 +11,18 @@ PROJECT = tildefriends
 | 
				
			|||||||
BUILD_DIR ?= out
 | 
					BUILD_DIR ?= out
 | 
				
			||||||
UNAME_S := $(shell uname -s)
 | 
					UNAME_S := $(shell uname -s)
 | 
				
			||||||
UNAME_M := $(shell uname -m)
 | 
					UNAME_M := $(shell uname -m)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ANDROID_SDK ?= ~/Android/Sdk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(UNAME_S),Darwin)
 | 
					ifeq ($(UNAME_S),Darwin)
 | 
				
			||||||
BUILD_TYPES := macosdebug macosrelease iosdebug iosrelease iossimdebug iossimrelease
 | 
					BUILD_TYPES := macosdebug macosrelease iosdebug iosrelease iossimdebug iossimrelease
 | 
				
			||||||
EXTRA_BUILD_TYPES :=
 | 
					 | 
				
			||||||
else ifeq ($(UNAME_S),Linux)
 | 
					else ifeq ($(UNAME_S),Linux)
 | 
				
			||||||
BUILD_TYPES := debug release
 | 
					BUILD_TYPES := debug release
 | 
				
			||||||
EXTRA_BUILD_TYPES := windebug winrelease androiddebug androidrelease androiddebug-x86 androidrelease-x86 androiddebug-x86_64 androidrelease-x86_64 androiddebug-armv7a androidrelease-armv7a iosdebug iosrelease
 | 
					HAVE_ANDROID = $(if $(shell which $(ANDROID_SDK)/platform-tools/adb),1,0)
 | 
				
			||||||
 | 
					HAVE_LINUX_IOS = $(if $(shell which deps/ios_toolchain/target/bin deps/ios_toolchain/target/bin/arm-apple-darwin11-clang),1,0)
 | 
				
			||||||
 | 
					HAVE_WIN = $(if $(shell which x86_64-w64-mingw32-gcc-win32),1,0)
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					$(error Unexpected host platform $(UNAME_S).)
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CFLAGS += \
 | 
					CFLAGS += \
 | 
				
			||||||
@@ -29,7 +35,6 @@ CFLAGS += \
 | 
				
			|||||||
	-fno-exceptions \
 | 
						-fno-exceptions \
 | 
				
			||||||
	-g
 | 
						-g
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ANDROID_SDK ?= ~/Android/Sdk
 | 
					 | 
				
			||||||
ANDROID_BUILD_TOOLS := $(ANDROID_SDK)/build-tools/33.0.1
 | 
					ANDROID_BUILD_TOOLS := $(ANDROID_SDK)/build-tools/33.0.1
 | 
				
			||||||
ANDROID_PLATFORM := $(ANDROID_SDK)/platforms/android-33
 | 
					ANDROID_PLATFORM := $(ANDROID_SDK)/platforms/android-33
 | 
				
			||||||
ANDROID_NDK ?= $(ANDROID_SDK)/ndk/23.1.7779620
 | 
					ANDROID_NDK ?= $(ANDROID_SDK)/ndk/23.1.7779620
 | 
				
			||||||
@@ -52,12 +57,21 @@ ANDROID_TARGETS := \
 | 
				
			|||||||
	$(ANDROID_X86_64_TARGETS) \
 | 
						$(ANDROID_X86_64_TARGETS) \
 | 
				
			||||||
	$(ANDROID_ARMV7A_TARGETS) \
 | 
						$(ANDROID_ARMV7A_TARGETS) \
 | 
				
			||||||
	$(ANDROID_ARM64_TARGETS)
 | 
						$(ANDROID_ARM64_TARGETS)
 | 
				
			||||||
LINUX_TARGETS := \
 | 
					ifeq ($(HAVE_ANDROID),1)
 | 
				
			||||||
	out/debug/tildefriends \
 | 
					BUILD_TYPES += $(ANDROID_TARGETS)
 | 
				
			||||||
	out/release/tildefriends
 | 
					all: out/TildeFriends-debug.apk out/TildeFriends-release.apk
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
WINDOWS_TARGETS := \
 | 
					WINDOWS_TARGETS := \
 | 
				
			||||||
	out/windebug/tildefriends.exe \
 | 
						out/windebug/tildefriends.exe \
 | 
				
			||||||
	out/winrelease/tildefriends.exe
 | 
						out/winrelease/tildefriends.exe
 | 
				
			||||||
 | 
					ifeq ($(HAVE_WIN),1)
 | 
				
			||||||
 | 
					BUILD_TYPES += windebug winrelease
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					LINUX_TARGETS := \
 | 
				
			||||||
 | 
						out/debug/tildefriends \
 | 
				
			||||||
 | 
						out/release/tildefriends
 | 
				
			||||||
MACOS_TARGETS := \
 | 
					MACOS_TARGETS := \
 | 
				
			||||||
	out/macosdebug/tildefriends \
 | 
						out/macosdebug/tildefriends \
 | 
				
			||||||
	out/macosrelease/tildefriends
 | 
						out/macosrelease/tildefriends
 | 
				
			||||||
@@ -67,6 +81,18 @@ IOS_TARGETS := \
 | 
				
			|||||||
IOSSIM_TARGETS := \
 | 
					IOSSIM_TARGETS := \
 | 
				
			||||||
	out/iossimdebug/tildefriends \
 | 
						out/iossimdebug/tildefriends \
 | 
				
			||||||
	out/iossimrelease/tildefriends
 | 
						out/iossimrelease/tildefriends
 | 
				
			||||||
 | 
					IOS_APPS = \
 | 
				
			||||||
 | 
						out/tildefriends-iosdebug.app/tildefriends \
 | 
				
			||||||
 | 
						out/tildefriends-iosrelease.app/tildefriends
 | 
				
			||||||
 | 
					ifeq ($(HAVE_LINUX_IOS),1)
 | 
				
			||||||
 | 
					BUILD_TYPES += iosdebug iosrelease
 | 
				
			||||||
 | 
					all: $(IOS_APPS)
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					ifeq ($(UNAME_S),Darwin)
 | 
				
			||||||
 | 
					all: $(IOS_APPS) \
 | 
				
			||||||
 | 
						out/tildefriends-iossimdebug.app/tildefriends \
 | 
				
			||||||
 | 
						out/tildefriends-iossimrelease.app/tildefriends
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DEBUG_TARGETS := \
 | 
					DEBUG_TARGETS := \
 | 
				
			||||||
	out/debug/tildefriends \
 | 
						out/debug/tildefriends \
 | 
				
			||||||
@@ -161,7 +187,7 @@ debug: LDFLAGS += -fsanitize=address -fsanitize=undefined
 | 
				
			|||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
get_objs = \
 | 
					get_objs = \
 | 
				
			||||||
	$(foreach build_type,$(BUILD_TYPES) $(EXTRA_BUILD_TYPES),$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)))))) \
 | 
						$(foreach build_type,$(BUILD_TYPES),$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)))))) \
 | 
				
			||||||
	$(foreach build_type,debug release,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_unix))))) \
 | 
						$(foreach build_type,debug release,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_unix))))) \
 | 
				
			||||||
	$(foreach build_type,windebug winrelease,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_win))))) \
 | 
						$(foreach build_type,windebug winrelease,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_win))))) \
 | 
				
			||||||
	$(foreach build_type,androiddebug androidrelease androiddebug-x86 androidrelease-x86 androiddebug-x86_64 androidrelease-x86_64 androiddebug-armv7a androiddebug-armv7a,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_android))))) \
 | 
						$(foreach build_type,androiddebug androidrelease androiddebug-x86 androidrelease-x86 androiddebug-x86_64 androidrelease-x86_64 androiddebug-armv7a androiddebug-armv7a,$(addprefix $(BUILD_DIR)/$(build_type)/,$(addsuffix .o,$(basename $(value $(1)_android))))) \
 | 
				
			||||||
@@ -523,12 +549,6 @@ $(IOS_TARGETS) $(IOSSIM_TARGETS): LDFLAGS += \
 | 
				
			|||||||
unix: debug release
 | 
					unix: debug release
 | 
				
			||||||
win: windebug winrelease
 | 
					win: windebug winrelease
 | 
				
			||||||
all: $(BUILD_TYPES)
 | 
					all: $(BUILD_TYPES)
 | 
				
			||||||
ifeq ($(UNAME_S),Linux)
 | 
					 | 
				
			||||||
all: out/TildeFriends-debug.apk out/TildeFriends-release.apk
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
ifeq ($(UNAME_S),Darwin)
 | 
					 | 
				
			||||||
all: out/tildefriends-iosdebug.app/tildefriends out/tildefriends-iosrelease.app/tildefriends out/tildefriends-iossimdebug.app/tildefriends out/tildefriends-iossimrelease.app/tildefriends
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
.PHONY: all win unix
 | 
					.PHONY: all win unix
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ALL_APP_OBJS := \
 | 
					ALL_APP_OBJS := \
 | 
				
			||||||
@@ -570,7 +590,7 @@ $(BUILD_DIR)/$(1)/%.o: %.S
 | 
				
			|||||||
	@$$(AS) -c $$< -o $$@
 | 
						@$$(AS) -c $$< -o $$@
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(foreach build_type,$(BUILD_TYPES) $(EXTRA_BUILD_TYPES),$(eval $(call build_rules,$(build_type))))
 | 
					$(foreach build_type,$(BUILD_TYPES),$(eval $(call build_rules,$(build_type))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
src/version.h : $(firstword $(MAKEFILE_LIST))
 | 
					src/version.h : $(firstword $(MAKEFILE_LIST))
 | 
				
			||||||
	@echo [version] $@
 | 
						@echo [version] $@
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user