aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--gyp/common_conditions.gypi11
-rw-r--r--gyp/common_variables.gypi2
-rwxr-xr-xtools/find_mac_sdk.py63
3 files changed, 74 insertions, 2 deletions
diff --git a/gyp/common_conditions.gypi b/gyp/common_conditions.gypi
index d1368ddacb..cfcc7f2c0d 100644
--- a/gyp/common_conditions.gypi
+++ b/gyp/common_conditions.gypi
@@ -195,6 +195,9 @@
['skia_os == "mac"',
{
+ 'variables': {
+ 'mac_sdk%': '<!(python <(DEPTH)/tools/find_mac_sdk.py 10.6)',
+ },
'defines': [
'SK_BUILD_FOR_MAC',
],
@@ -228,7 +231,13 @@
},
'xcode_settings': {
'GCC_SYMBOLS_PRIVATE_EXTERN': 'NO',
- 'SDKROOT': '<(skia_osx_sdkroot)',
+ 'conditions': [
+ ['skia_osx_sdkroot==""', {
+ 'SDKROOT': 'macosx<(mac_sdk)', # -isysroot
+ }, {
+ 'SDKROOT': '<(skia_osx_sdkroot)', # -isysroot
+ }],
+ ],
# trying to get this to work, but it needs clang I think...
# 'WARNING_CFLAGS': '-Wexit-time-destructors',
'CLANG_WARN_CXX0X_EXTENSIONS': 'NO',
diff --git a/gyp/common_variables.gypi b/gyp/common_variables.gypi
index 5aca19c23b..13e681dcc6 100644
--- a/gyp/common_variables.gypi
+++ b/gyp/common_variables.gypi
@@ -87,7 +87,7 @@
'skia_angle%': 0,
'skia_directwrite%': 0,
'skia_gpu%': 1,
- 'skia_osx_sdkroot%': 'macosx',
+ 'skia_osx_sdkroot%': '',
'skia_profile_enabled%': 0,
# Note: This is currently only turned on for linux and android.
# TODO: Turn on for Win and Mac as well.
diff --git a/tools/find_mac_sdk.py b/tools/find_mac_sdk.py
new file mode 100755
index 0000000000..6ffee38f19
--- /dev/null
+++ b/tools/find_mac_sdk.py
@@ -0,0 +1,63 @@
+#!/usr/bin/env python
+# Copyright (c) 2012 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+import os
+import re
+import subprocess
+import sys
+
+"""Prints the lowest locally available SDK version greater than or equal to a
+given minimum sdk version to standard output.
+
+Usage:
+ python find_sdk.py 10.6 # Ignores SDKs < 10.6
+"""
+
+def parse_version(version_str):
+ """'10.6' => [10, 6]"""
+ return map(int, re.findall(r'(\d+)', version_str))
+
+def find_sdk_dir():
+ job = subprocess.Popen(['xcode-select', '-print-path'],
+ stdout=subprocess.PIPE,
+ stderr=subprocess.STDOUT)
+ out, err = job.communicate()
+ if job.returncode != 0:
+ print >>sys.stderr, out
+ print >>sys.stderr, err
+ raise Exception(('Error %d running xcode-select, you might have to run '
+ '|sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer| '
+ 'if you are using Xcode 4.') % job.returncode)
+ # The Developer folder moved in Xcode 4.3.
+ xcode43_sdk_path = os.path.join(
+ out.rstrip(), 'Platforms/MacOSX.platform/Developer/SDKs')
+ if os.path.isdir(xcode43_sdk_path):
+ sdk_dir = xcode43_sdk_path
+ else:
+ sdk_dir = os.path.join(out.rstrip(), 'SDKs')
+
+ return sdk_dir
+
+def main():
+ min_sdk_version = '10.6'
+ if len(sys.argv) > 0:
+ min_sdk_version = sys.argv[0]
+
+ sdk_dir = find_sdk_dir()
+
+ sdks = [re.findall('^MacOSX(10\.\d+)\.sdk$', s) for s in os.listdir(sdk_dir)]
+ sdks = [s[0] for s in sdks if s] # [['10.5'], ['10.6']] => ['10.5', '10.6']
+ sdks = [s for s in sdks # ['10.5', '10.6'] => ['10.6']
+ if parse_version(s) >= parse_version(min_sdk_version)]
+ if not sdks:
+ raise Exception('No %s+ SDK found' % min_sdk_version)
+ best_sdk = sorted(sdks, key=parse_version)[0]
+
+ return best_sdk
+
+if __name__ == '__main__':
+ if sys.platform != 'darwin':
+ raise Exception("This script only runs on Mac")
+ print main()