2019-04-23 17:05:21 +00:00
|
|
|
#!/usr/bin/python2
|
|
|
|
#
|
|
|
|
# Copyright 2019 Google Inc.
|
|
|
|
#
|
|
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
|
|
# found in the LICENSE file.
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
|
|
|
roots = [
|
|
|
|
'bench',
|
|
|
|
'dm',
|
|
|
|
'docs',
|
|
|
|
'example',
|
|
|
|
'experimental',
|
|
|
|
'fuzz',
|
|
|
|
'gm',
|
|
|
|
'include',
|
|
|
|
'modules',
|
|
|
|
'platform_tools/android/apps',
|
|
|
|
'samplecode',
|
|
|
|
'src',
|
|
|
|
'tests',
|
2019-04-24 17:46:06 +00:00
|
|
|
'third_party/etc1',
|
2019-04-23 17:05:21 +00:00
|
|
|
'third_party/gif',
|
|
|
|
'tools'
|
|
|
|
]
|
|
|
|
|
2019-07-25 16:18:06 +00:00
|
|
|
# Don't count our local Vulkan headers as Skia headers;
|
|
|
|
# we don't want #include <vulkan/vulkan_foo.h> rewritten to point to them.
|
|
|
|
blacklist = ['include/third_party/vulkan']
|
2019-07-25 14:00:52 +00:00
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
# Map short name -> absolute path for all Skia headers.
|
|
|
|
headers = {}
|
|
|
|
for root in roots:
|
|
|
|
for path, _, files in os.walk(root):
|
2019-07-25 16:18:06 +00:00
|
|
|
if not any(snippet in path for snippet in blacklist):
|
|
|
|
for file_name in files:
|
|
|
|
if file_name.endswith('.h'):
|
|
|
|
if file_name in headers:
|
|
|
|
print path, file_name, headers[file_name]
|
|
|
|
assert file_name not in headers
|
|
|
|
headers[file_name] = os.path.abspath(os.path.join(path, file_name))
|
2019-04-23 17:05:21 +00:00
|
|
|
|
|
|
|
# Rewrite any #includes relative to Skia's top-level directory.
|
|
|
|
for root in roots:
|
|
|
|
for path, _, files in os.walk(root):
|
|
|
|
if 'generated' in path:
|
|
|
|
continue
|
|
|
|
for file_name in files:
|
|
|
|
if (file_name.endswith('.h') or
|
|
|
|
file_name.endswith('.c') or
|
|
|
|
file_name.endswith('.m') or
|
|
|
|
file_name.endswith('.mm') or
|
|
|
|
file_name.endswith('.inc') or
|
|
|
|
file_name.endswith('.fp') or
|
|
|
|
file_name.endswith('.cc') or
|
|
|
|
file_name.endswith('.cpp')):
|
|
|
|
# Read the whole file into memory.
|
|
|
|
file_path = os.path.join(path, file_name)
|
|
|
|
lines = open(file_path).readlines()
|
|
|
|
|
|
|
|
# Write it back out again line by line with substitutions for #includes.
|
|
|
|
with open(file_path, 'w') as output:
|
|
|
|
includes = []
|
|
|
|
|
|
|
|
for line in lines:
|
2019-07-25 16:18:06 +00:00
|
|
|
parts = line.replace('<', '"').replace('>', '"').split('"')
|
2019-04-23 17:05:21 +00:00
|
|
|
if (len(parts) == 3
|
|
|
|
and '#' in parts[0]
|
|
|
|
and 'include' in parts[0]
|
|
|
|
and os.path.basename(parts[1]) in headers):
|
|
|
|
header = headers[os.path.basename(parts[1])]
|
2019-05-14 19:01:39 +00:00
|
|
|
includes.append(parts[0] +
|
|
|
|
'"%s"' % os.path.relpath(header, '.') +
|
|
|
|
parts[2])
|
2019-04-23 17:05:21 +00:00
|
|
|
else:
|
|
|
|
for inc in sorted(includes):
|
2019-05-14 19:01:39 +00:00
|
|
|
print >>output, inc.strip('\n')
|
2019-04-23 17:05:21 +00:00
|
|
|
includes = []
|
|
|
|
print >>output, line.strip('\n')
|
|
|
|
|