Merge pull request #166 from benson-basis/modern_osx_java

Use the java from java_home on OSX.
This commit is contained in:
dessant 2015-11-03 14:00:23 +02:00
commit 51ebed91d7
1 changed files with 11 additions and 3 deletions

View File

@ -45,12 +45,20 @@ if platform == 'android':
library_dirs = ['libs/' + environ['ARCH']] library_dirs = ['libs/' + environ['ARCH']]
elif platform == 'darwin': elif platform == 'darwin':
import subprocess import subprocess
framework = subprocess.Popen('xcrun --sdk macosx --show-sdk-path', framework = subprocess.Popen('/usr/libexec/java_home',
shell=True, stdout=subprocess.PIPE).communicate()[0].strip() shell=True, stdout=subprocess.PIPE).communicate()[0].strip()
print('java_home: {0}\n'.format(framework));
if not framework: if not framework:
raise Exception('You must install Java on your Mac OS X distro') raise Exception('You must install Java on your Mac OS X distro')
if '1.6' in framework:
extra_link_args = ['-framework', 'JavaVM'] extra_link_args = ['-framework', 'JavaVM']
include_dirs = [join(framework, 'System/Library/Frameworks/JavaVM.framework/Versions/Current/Headers')] include_dirs = [join(framework, 'System/Library/Frameworks/JavaVM.framework/Versions/Current/Headers')]
else:
# TODO: This won't make a dylib that moves from one machine to another.
# TODO: it needs a switch to dlopen and a configuration of the path.
java_runtime_lib = '{0}/jre/lib/server'.format(framework)
extra_link_args = ['-L', java_runtime_lib, '-ljvm', '-rpath', java_runtime_lib]
include_dirs = ['{0}/include'.format(framework), '{0}/include/darwin'.format(framework)]
else: else:
import subprocess import subprocess
# otherwise, we need to search the JDK_HOME # otherwise, we need to search the JDK_HOME