diff options
author | phajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-01-15 17:34:31 +0000 |
---|---|---|
committer | phajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-01-15 17:34:31 +0000 |
commit | 46aa05cc4233d50f361375d11227648f232129d3 (patch) | |
tree | 737aa4ce172841536196c0ae605b5bd17d78a480 /tools/generate_shim_headers/generate_shim_headers.py | |
parent | 4ebf2a9e3ab572b6b9d911c4d1058a4e5f8eafe5 (diff) | |
download | chromium_src-46aa05cc4233d50f361375d11227648f232129d3.zip chromium_src-46aa05cc4233d50f361375d11227648f232129d3.tar.gz chromium_src-46aa05cc4233d50f361375d11227648f232129d3.tar.bz2 |
Linux: use generated shim headers for system mesa.
BUG=161389, 165264
Review URL: https://codereview.chromium.org/11693007
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@176926 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'tools/generate_shim_headers/generate_shim_headers.py')
-rwxr-xr-x | tools/generate_shim_headers/generate_shim_headers.py | 50 |
1 files changed, 36 insertions, 14 deletions
diff --git a/tools/generate_shim_headers/generate_shim_headers.py b/tools/generate_shim_headers/generate_shim_headers.py index 068a2ac..f0a5c99 100755 --- a/tools/generate_shim_headers/generate_shim_headers.py +++ b/tools/generate_shim_headers/generate_shim_headers.py @@ -21,15 +21,14 @@ SHIM_TEMPLATE = """ #if defined(OFFICIAL_BUILD) #error shim headers must not be used in official builds! #endif - -#include <%s> """ def GeneratorMain(argv): parser = optparse.OptionParser() - parser.add_option('--headers-root') + parser.add_option('--headers-root', action='append') parser.add_option('--output-directory') + parser.add_option('--use-include-next', action='store_true') parser.add_option('--outputs', action='store_true') parser.add_option('--generate', action='store_true') @@ -45,17 +44,40 @@ def GeneratorMain(argv): source_tree_root = os.path.abspath( os.path.join(os.path.dirname(__file__), '..', '..')) - target_directory = os.path.join( - options.output_directory, - os.path.relpath(options.headers_root, source_tree_root)) - if options.generate and not os.path.exists(target_directory): - os.makedirs(target_directory) - for header_filename in args: - if options.outputs: - yield os.path.join(target_directory, header_filename) - if options.generate: - with open(os.path.join(target_directory, header_filename), 'w') as f: - f.write(SHIM_TEMPLATE % header_filename) + for root in options.headers_root: + target_directory = os.path.join( + options.output_directory, + os.path.relpath(root, source_tree_root)) + if options.generate and not os.path.exists(target_directory): + os.makedirs(target_directory) + + for header_spec in args: + if ';' in header_spec: + (header_filename, + include_before, + include_after) = header_spec.split(';', 2) + else: + header_filename = header_spec + include_before = '' + include_after = '' + if options.outputs: + yield os.path.join(target_directory, header_filename) + if options.generate: + with open(os.path.join(target_directory, header_filename), 'w') as f: + f.write(SHIM_TEMPLATE) + + if include_before: + for header in include_before.split(':'): + f.write('#include %s\n' % header) + + if options.use_include_next: + f.write('#include_next <%s>\n' % header_filename) + else: + f.write('#include <%s>\n' % header_filename) + + if include_after: + for header in include_after.split(':'): + f.write('#include %s\n' % header) def DoMain(argv): |