summaryrefslogtreecommitdiffstats
path: root/tools/generate_shim_headers/generate_shim_headers.py
diff options
context:
space:
mode:
authorphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-01-15 17:34:31 +0000
committerphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-01-15 17:34:31 +0000
commit46aa05cc4233d50f361375d11227648f232129d3 (patch)
tree737aa4ce172841536196c0ae605b5bd17d78a480 /tools/generate_shim_headers/generate_shim_headers.py
parent4ebf2a9e3ab572b6b9d911c4d1058a4e5f8eafe5 (diff)
downloadchromium_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-xtools/generate_shim_headers/generate_shim_headers.py50
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):