summaryrefslogtreecommitdiff
path: root/os
diff options
context:
space:
mode:
authorbjarni <bjarni@openttd.org>2005-12-09 12:15:52 +0000
committerbjarni <bjarni@openttd.org>2005-12-09 12:15:52 +0000
commit111e5ef0fdb06518c9cea7705653526c403c21c0 (patch)
tree324b2ec489c537c885f5f3b3634b1ee8d265c47a /os
parent578883266f1c7c1d5825b99e8474694b3423bafe (diff)
downloadopenttd-111e5ef0fdb06518c9cea7705653526c403c21c0.tar.xz
(svn r3274) -Fix: [OSX] added JAGUAR flag to crosscompile for OSX 10.2 (codenamed jaguar)
JAGUAR and FAT_BINARY can't be used at the same time JAGUAR will disable network support due to missing libs in 10.2
Diffstat (limited to 'os')
-rw-r--r--os/macosx/Makefile19
-rw-r--r--os/macosx/Makefile.setup28
2 files changed, 40 insertions, 7 deletions
diff --git a/os/macosx/Makefile b/os/macosx/Makefile
index 577bf420a..4f952de8b 100644
--- a/os/macosx/Makefile
+++ b/os/macosx/Makefile
@@ -4,7 +4,7 @@
ifdef FAT_BINARY
FAT_BINARY:=build_universal_binary
-COPY_x86_SDL_LIB:=$(Q)cp $(x86_SDL_LIB) $(OSXAPP)/Contents/lib/libSDL-x86.dylib
+POST_BUNDLE_BUILDING:=$(Q)cp $(x86_SDL_LIB) $(OSXAPP)/Contents/lib/libSDL-x86.dylib
endif
ifdef UNIVERSAL_x86_PART
@@ -14,6 +14,17 @@ else
BUILD_OSX_BUNDLE:=build_OSX_bundle
endif
+ifdef JAGUAR
+JAGUAR:=jaguar
+POST_BUNDLE_BUILDING:=$(Q)cp /usr/lib/libmx.A.dylib $(OSXAPP)/Contents/lib/libmx.A.dylib
+endif
+
+# MacOS X got some issues in OpenTTD, so we got a workaround target to solve them
+# only network support will not be fixed this way, so we will have a binary without network support
+
+$(JAGUAR):
+ $(Q)install_name_tool -change /usr/lib/libmx.A.dylib @executable_path/../lib/libmx.A.dylib $(TTD)
+
# building an universal binary
# since we can only compile for PPC or x86 at any one time, we compile one and then
# we make clean and compile the other one. In the end we use lipo to join them together
@@ -33,7 +44,7 @@ $(FAT_BINARY): $(TTD)
# build the bundle. OSX wants to keep apps in bundles, so we will give it one
# the good thing about bundles is that you can keep extra files in them, so we keep lng files and a data dir in it
-$(BUILD_OSX_BUNDLE): $(TTD) $(FAT_BINARY)
+$(BUILD_OSX_BUNDLE): $(TTD) $(FAT_BINARY) $(JAGUAR)
@echo '===> Building application bundle'
$(Q)rm -fr "$(OSXAPP)"
$(Q)mkdir -p "$(OSXAPP)"/Contents/MacOS
@@ -47,7 +58,7 @@ $(BUILD_OSX_BUNDLE): $(TTD) $(FAT_BINARY)
$(Q)cp data/* "$(OSXAPP)"/Contents/Data/
$(Q)cp lang/*.lng "$(OSXAPP)"/Contents/Lang/
$(Q)cp $(TTD) "$(OSXAPP)"/Contents/MacOS/$(TTD)
- $(COPY_x86_SDL_LIB)
+ $(POST_BUNDLE_BUILDING)
# make the release disk image. Should only be used with releases and is a good and fast way to make sure to remember all the needed files
release: all
@@ -70,4 +81,4 @@ release: all
$(OSX): $(TTD) $(BUILD_OSX_BUNDLE)
-.PHONY: release $(BUILD_OSX_BUNDLE) $(FAT_BINARY)
+.PHONY: release $(BUILD_OSX_BUNDLE) $(FAT_BINARY) $(JAGUAR)
diff --git a/os/macosx/Makefile.setup b/os/macosx/Makefile.setup
index f42f34bf4..01c2813af 100644
--- a/os/macosx/Makefile.setup
+++ b/os/macosx/Makefile.setup
@@ -29,16 +29,29 @@ $(warning Compiling a release build, that is a debug build)
endif
endif
+ifdef JAGUAR
+ifdef FAT_BINARY
+$(error FAT_BINARY and JAGUAR can't be used at the same time)
+endif
+endif
+
# setup flags if none are defined
+ifndef CFLAGS_JAGUAR
+ CFLAGS_JAGUAR:= -isysroot /Developer/SDKs/MacOSX10.2.8.sdk
+endif
+ifndef LDFLAGS_JAGUAR
+ LDFLAGS_JAGUAR:= -Wl,-syslibroot,/Developer/SDKs/MacOSX10.2.8.sdk
+endif
+
+ifndef PPC_CC
+ PPC_CC:=powerpc-apple-darwin8-gcc-4.0.0
+endif
ifndef CFLAGS_PPC
CFLAGS_PPC:= -isysroot /Developer/SDKs/MacOSX10.3.9.sdk
endif
ifndef LDFLAGS_PPC
LDFLAGS_PPC:= -Wl,-syslibroot,/Developer/SDKs/MacOSX10.3.9.sdk
endif
-ifndef PPC_CC
- PPC_CC:=powerpc-apple-darwin8-gcc-4.0.0
-endif
ifndef CFLAGS_x86
CFLAGS_x86:= -isysroot /Developer/SDKs/MacOSX10.4u.sdk
endif
@@ -115,3 +128,12 @@ $(error no x86 SDL lib found)
LDFLAGS:= $(LDFLAGS_PPC)
endif
endif
+
+ifdef JAGUAR
+ CFLAGS:=$(CFLAGS_JAGUAR)
+ LDFLAGS:=$(LDFLAGS_JAGUAR)
+ # network support is broken is jaguar (OSX 10.2)
+ WITH_NETWORK:=
+ # crosscompiling for jaguar should always be static
+ STATIC:=1
+endif \ No newline at end of file