Index: build/gyp_chromium |
=================================================================== |
--- build/gyp_chromium (revision 166103) |
+++ build/gyp_chromium (working copy) |
@@ -8,7 +8,6 @@ |
# is invoked by Chromium beyond what can be done in the gclient hooks. |
import glob |
-import gyp_helper |
import os |
import shlex |
import subprocess |
@@ -45,6 +44,36 @@ |
else: |
psyco = None |
+def apply_gyp_environment(file_path=None): |
+ """ |
+ Reads in a *.gyp_env file and applies the valid keys to os.environ. |
+ """ |
+ if not file_path or not os.path.exists(file_path): |
+ return |
+ file_contents = open(file_path).read() |
+ try: |
+ file_data = eval(file_contents, {'__builtins__': None}, None) |
+ except SyntaxError, e: |
+ e.filename = os.path.abspath(file_path) |
+ raise |
+ supported_vars = ( 'CC', |
+ 'CHROMIUM_GYP_FILE', |
+ 'CHROMIUM_GYP_SYNTAX_CHECK', |
+ 'CXX', |
+ 'GYP_DEFINES', |
+ 'GYP_GENERATOR_FLAGS', |
+ 'GYP_GENERATOR_OUTPUT', |
+ 'GYP_GENERATORS', ) |
+ for var in supported_vars: |
+ val = file_data.get(var) |
+ if val: |
+ if var in os.environ: |
+ print 'INFO: Environment value for "%s" overrides value in %s.' % ( |
+ var, os.path.abspath(file_path) |
+ ) |
+ else: |
+ os.environ[var] = val |
+ |
def additional_include_files(args=[]): |
""" |
Returns a list of additional (.gypi) files to include, without |
@@ -95,7 +124,10 @@ |
p.communicate() |
sys.exit(p.returncode) |
- gyp_helper.apply_chromium_gyp_env() |
+ if 'SKIP_CHROMIUM_GYP_ENV' not in os.environ: |
+ # Update the environment based on chromium.gyp_env |
+ gyp_env_path = os.path.join(os.path.dirname(chrome_src), 'chromium.gyp_env') |
+ apply_gyp_environment(gyp_env_path) |
# This could give false positives since it doesn't actually do real option |
# parsing. Oh well. |