Chromium Code Reviews| Index: build/gyp_chromium |
| =================================================================== |
| --- build/gyp_chromium (revision 65393) |
| +++ build/gyp_chromium (working copy) |
| @@ -18,6 +18,31 @@ |
| sys.path.insert(0, os.path.join(chrome_src, 'tools', 'gyp', 'pylib')) |
| import gyp |
| +def apply_gyp_environment(file_path=None): |
| + """ |
| + Reads in a *.gyp_env and applies the valid keys to os.environ. |
|
Mark Mentovai
2010/11/08 19:58:21
*.gyp_env file.
|
| + """ |
| + 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 = ( 'CHROMIUM_GYP_FILE', |
| + 'CHROMIUM_GYP_SYNTAX_CHECK', |
| + 'GYP_DEFINES', |
| + 'GYP_GENERATOR_FLAGS', |
| + 'GYP_GENERATOR_OUTPUT', ) |
| + for var in supported_vars: |
| + val = file_data.get(var) |
| + if val: |
| + existing_value = os.environ.get(var) |
| + if existing_value: |
|
Mark Mentovai
2010/11/08 19:58:21
I would prefer not overwriting existing values at
|
| + val = existing_value + ' ' + val |
| + os.environ[var] = val |
| + |
| def additional_include_files(args=[]): |
| """ |
| Returns a list of additional (.gypi) files to include, without |
| @@ -51,6 +76,11 @@ |
| if __name__ == '__main__': |
| args = sys.argv[1:] |
| + if 'SKIP_CHROMIUM_GYP_ENV' not in os.environ: |
| + # Update the environment based on .gyp_env |
|
Mark Mentovai
2010/11/08 19:58:21
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. |
| gyp_file_specified = False |