mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
fix Android classpath build for iOS
This mainly involved reworking the makefile to avoid conflating Darwin/ARM builds with iOS, since we may also want to build for the iOS Simulator, which is i386. Note that I was only able to test this on the Simulator, since I don't have a real iOS device to test with. Sorry if I broke something; if so, please fix it :)
This commit is contained in:
parent
56a0aea160
commit
c06dd28ea0
69
makefile
69
makefile
@ -170,6 +170,7 @@ ifneq ($(android),)
|
|||||||
-D_FILE_OFFSET_BITS=64 \
|
-D_FILE_OFFSET_BITS=64 \
|
||||||
-DOS_SHARED_LIB_FORMAT_STR="\"$(so-prefix)%s$(so-suffix)\"" \
|
-DOS_SHARED_LIB_FORMAT_STR="\"$(so-prefix)%s$(so-suffix)\"" \
|
||||||
-DJNI_JARJAR_PREFIX= \
|
-DJNI_JARJAR_PREFIX= \
|
||||||
|
-D__DARWIN_UNIX03=1 \
|
||||||
-g3 \
|
-g3 \
|
||||||
-Werror
|
-Werror
|
||||||
|
|
||||||
@ -445,19 +446,7 @@ ifeq ($(arch),arm)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(arch),$(build-arch))
|
ifneq ($(arch),$(build-arch))
|
||||||
ifeq ($(platform),darwin)
|
ifneq ($(platform),darwin)
|
||||||
ios-bin = $(developer-dir)/Platforms/iPhoneOS.platform/Developer/usr/bin
|
|
||||||
ifeq ($(use-clang),true)
|
|
||||||
cxx = clang -std=c++11
|
|
||||||
cc = clang
|
|
||||||
else
|
|
||||||
cxx = $(ios-bin)/g++
|
|
||||||
cc = $(ios-bin)/gcc
|
|
||||||
endif
|
|
||||||
ar = $(ios-bin)/ar
|
|
||||||
ranlib = $(ios-bin)/ranlib
|
|
||||||
strip = $(ios-bin)/strip
|
|
||||||
else
|
|
||||||
cxx = arm-linux-gnueabi-g++
|
cxx = arm-linux-gnueabi-g++
|
||||||
cc = arm-linux-gnueabi-gcc
|
cc = arm-linux-gnueabi-gcc
|
||||||
ar = arm-linux-gnueabi-ar
|
ar = arm-linux-gnueabi-ar
|
||||||
@ -616,24 +605,53 @@ ifeq ($(platform),darwin)
|
|||||||
shared = -dynamiclib
|
shared = -dynamiclib
|
||||||
rpath =
|
rpath =
|
||||||
|
|
||||||
sdk-dir = $(developer-dir)/Platforms/iPhoneOS.platform/Developer/SDKs
|
ifeq ($(ios),true)
|
||||||
|
ifeq ($(arch),i386)
|
||||||
|
target = iPhoneSimulator
|
||||||
|
sdk = iphonesimulator$(ios-version)
|
||||||
|
arch = i386
|
||||||
|
arch-flag = -arch i386
|
||||||
|
release = Release-iphonesimulator
|
||||||
|
else
|
||||||
|
target = iPhoneOS
|
||||||
|
sdk = iphoneos$(ios-version)
|
||||||
|
arch = arm
|
||||||
|
arch-flag = -arch armv7
|
||||||
|
release = Release-iphoneos
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(arch),arm)
|
platform-dir = $(developer-dir)/Platforms/$(target).platform
|
||||||
ios-version := \
|
sdk-dir = $(platform-dir)/Developer/SDKs
|
||||||
$(shell if test -d $(sdk-dir)/iPhoneOS6.1.sdk; then echo 6.1; \
|
|
||||||
elif test -d $(sdk-dir)/iPhoneOS6.0.sdk; then echo 6.0; \
|
ios-version := $(shell \
|
||||||
elif test -d $(sdk-dir)/iPhoneOS5.1.sdk; then echo 5.1; \
|
if test -d $(sdk-dir)/$(target)6.1.sdk; then echo 6.1; \
|
||||||
elif test -d $(sdk-dir)/iPhoneOS5.0.sdk; then echo 5.0; \
|
elif test -d $(sdk-dir)/$(target)6.0.sdk; then echo 6.0; \
|
||||||
elif test -d $(sdk-dir)/iPhoneOS4.3.sdk; then echo 4.3; \
|
elif test -d $(sdk-dir)/$(target)5.1.sdk; then echo 5.1; \
|
||||||
elif test -d $(sdk-dir)/iPhoneOS4.2.sdk; then echo 4.2; \
|
elif test -d $(sdk-dir)/$(target)5.0.sdk; then echo 5.0; \
|
||||||
|
elif test -d $(sdk-dir)/$(target)4.3.sdk; then echo 4.3; \
|
||||||
|
elif test -d $(sdk-dir)/$(target)4.2.sdk; then echo 4.2; \
|
||||||
else echo; fi)
|
else echo; fi)
|
||||||
|
|
||||||
ifeq ($(ios-version),)
|
ifeq ($(ios-version),)
|
||||||
x := $(error "couldn't find SDK for iOS version")
|
x := $(error "couldn't find SDK")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
flags = -arch armv7 -isysroot \
|
ios-bin = $(platform-dir)/Developer/usr/bin
|
||||||
$(sdk-dir)/iPhoneOS$(ios-version).sdk/
|
|
||||||
|
ifeq ($(use-clang),true)
|
||||||
|
cxx = clang -std=c++11
|
||||||
|
cc = clang
|
||||||
|
else
|
||||||
|
cxx = $(ios-bin)/g++
|
||||||
|
cc = $(ios-bin)/gcc
|
||||||
|
endif
|
||||||
|
ar = $(ios-bin)/ar
|
||||||
|
ranlib = $(ios-bin)/ranlib
|
||||||
|
strip = $(ios-bin)/strip
|
||||||
|
|
||||||
|
flags = -isysroot $(sdk-dir)/$(target)$(ios-version).sdk \
|
||||||
|
$(arch-flag)
|
||||||
|
|
||||||
classpath-extra-cflags += $(flags)
|
classpath-extra-cflags += $(flags)
|
||||||
cflags += $(flags)
|
cflags += $(flags)
|
||||||
asmflags += $(flags)
|
asmflags += $(flags)
|
||||||
@ -1811,6 +1829,7 @@ $(audit-codegen-executable): $(audit-codegen-executable-objects)
|
|||||||
$(bootimage-generator): $(bootimage-generator-objects) $(vm-objects)
|
$(bootimage-generator): $(bootimage-generator-objects) $(vm-objects)
|
||||||
echo building $(bootimage-generator) arch=$(build-arch) platform=$(bootimage-platform)
|
echo building $(bootimage-generator) arch=$(build-arch) platform=$(bootimage-platform)
|
||||||
$(MAKE) mode=$(mode) \
|
$(MAKE) mode=$(mode) \
|
||||||
|
ios=false \
|
||||||
build=$(host-build-root) \
|
build=$(host-build-root) \
|
||||||
arch=$(build-arch) \
|
arch=$(build-arch) \
|
||||||
aot-only=false \
|
aot-only=false \
|
||||||
|
@ -452,7 +452,7 @@ class MyClasspath : public Classpath {
|
|||||||
// LD_LIBRARY_PATH is not set as of this writing:
|
// LD_LIBRARY_PATH is not set as of this writing:
|
||||||
#ifdef PLATFORM_WINDOWS
|
#ifdef PLATFORM_WINDOWS
|
||||||
_wputenv(L"LD_LIBRARY_PATH=(dummy)");
|
_wputenv(L"LD_LIBRARY_PATH=(dummy)");
|
||||||
#else
|
#elif (! defined AVIAN_IOS)
|
||||||
setenv("LD_LIBRARY_PATH", "", false);
|
setenv("LD_LIBRARY_PATH", "", false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user