| Index: tools/resources/generate_resource_whitelist.py
|
| diff --git a/tools/resources/find_used_resources.py b/tools/resources/generate_resource_whitelist.py
|
| similarity index 59%
|
| rename from tools/resources/find_used_resources.py
|
| rename to tools/resources/generate_resource_whitelist.py
|
| index 0528115ead59cfadbc1d16cb2b38090e48937a7a..527ceb484158c9fcf32cb5d9dc34e7561d7471d9 100755
|
| --- a/tools/resources/find_used_resources.py
|
| +++ b/tools/resources/generate_resource_whitelist.py
|
| @@ -1,5 +1,5 @@
|
| #!/usr/bin/env python
|
| -# Copyright 2014 The Chromium Authors. All rights reserved.
|
| +# Copyright 2016 The Chromium Authors. All rights reserved.
|
| # Use of this source code is governed by a BSD-style license that can be
|
| # found in the LICENSE file.
|
|
|
| @@ -8,18 +8,22 @@ import os
|
| import re
|
| import sys
|
|
|
| -USAGE = """find_used_resources.py [-h] [-i INPUT] [-o OUTPUT]
|
| +USAGE = """generate_resource_whitelist.py [-h] [-i INPUT] [-o OUTPUT]
|
|
|
| -Outputs the sorted list of resource ids that are part of unknown pragma warning
|
| -in the given build log.
|
| +INPUT specifies a file containing existing resource IDs that should be
|
| +whitelisted, where each line of INPUT contains a single resource ID.
|
| +
|
| +Creates a resource whitelist by collecting existing resource IDs that are part
|
| +of unknown pragma warnings and adds additional arch specfic resource IDs.
|
|
|
| This script is used to find the resources that are actually compiled in Chrome
|
| -in order to only include the needed strings/images in Chrome PAK files. The
|
| -script parses out the list of used resource ids. These resource ids show up in
|
| -the build output after building Chrome with gyp variable
|
| -enable_resource_whitelist_generation set to 1. This gyp flag causes the compiler
|
| -to print out a UnknownPragma message every time a resource id is used. E.g.:
|
| -foo.cc:22:0: warning: ignoring #pragma whitelisted_resource_12345
|
| +in order to only include the needed strings/images in Chrome PAK files.
|
| +These resource IDs show up in the build output after building Chrome with
|
| +gn variable enable_resource_whitelist_generation set to true.
|
| +This causes the compiler to print out an UnknownPragma message every time a
|
| +resource ID is used.
|
| +
|
| +E.g. foo.cc:22:0: warning: ignoring #pragma whitelisted_resource_12345
|
| [-Wunknown-pragmas]
|
|
|
| On Windows, the message is simply a message via __pragma(message(...)).
|
| @@ -35,7 +39,8 @@ ARCH_SPECIFIC_RESOURCES = [
|
| 'IDS_VERSION_UI_32BIT',
|
| ]
|
|
|
| -def FindResourceIds(header, resource_names):
|
| +
|
| +def _FindResourceIds(header, resource_names):
|
| """Returns the numerical resource IDs that correspond to the given resource
|
| names, as #defined in the given header file."
|
| """
|
| @@ -49,36 +54,24 @@ def FindResourceIds(header, resource_names):
|
| ', '.join(str(i) for i in res_ids))
|
| return set(res_ids)
|
|
|
| -def GetResourceIdsInPragmaWarnings(input):
|
| - """Returns set of resource ids that are inside unknown pragma warnings
|
| - for the given input.
|
| - """
|
| - used_resources = set()
|
| - unknown_pragma_warning_pattern = re.compile(
|
| - 'whitelisted_resource_(?P<resource_id>[0-9]+)')
|
| - for ln in input:
|
| - match = unknown_pragma_warning_pattern.search(ln)
|
| - if match:
|
| - resource_id = int(match.group('resource_id'))
|
| - used_resources.add(resource_id)
|
| - return used_resources
|
| -
|
| -def Main():
|
| +
|
| +def main():
|
| parser = argparse.ArgumentParser(usage=USAGE)
|
| parser.add_argument(
|
| '-i', '--input', type=argparse.FileType('r'), default=sys.stdin,
|
| - help='The build log to read (default stdin)')
|
| + help='A resource whitelist where each line contains one resource ID')
|
| parser.add_argument(
|
| '-o', '--output', type=argparse.FileType('w'), default=sys.stdout,
|
| help='The resource list path to write (default stdout)')
|
| - parser.add_argument('--out-dir', required=True,
|
| + parser.add_argument(
|
| + '--out-dir', required=True,
|
| help='The out target directory, for example out/Release')
|
|
|
| args = parser.parse_args()
|
|
|
| -
|
| - used_resources = GetResourceIdsInPragmaWarnings(args.input)
|
| - used_resources |= FindResourceIds(
|
| + used_resources = set()
|
| + used_resources.update([int(resource_id) for resource_id in args.input])
|
| + used_resources |= _FindResourceIds(
|
| os.path.join(args.out_dir, COMPONENTS_STRINGS_HEADER),
|
| ARCH_SPECIFIC_RESOURCES)
|
|
|
| @@ -86,4 +79,4 @@ def Main():
|
| args.output.write('%d\n' % resource_id)
|
|
|
| if __name__ == '__main__':
|
| - Main()
|
| + main()
|
|
|