Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # | 2 # |
| 3 # Copyright 2015 The Chromium Authors. All rights reserved. | 3 # Copyright 2015 The Chromium Authors. All rights reserved. |
| 4 # Use of this source code is governed by a BSD-style license that can be | 4 # Use of this source code is governed by a BSD-style license that can be |
| 5 # found in the LICENSE file. | 5 # found in the LICENSE file. |
| 6 | 6 |
| 7 '''Prepares the Google Play services split client libraries before usage by | 7 '''Prepares the Google Play services split client libraries before usage by |
| 8 Chrome's build system. | 8 Chrome's build system. |
| 9 | 9 |
| 10 We need to preprocess Google Play services before using it in Chrome builds | 10 We need to preprocess Google Play services before using it in Chrome builds |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 +-- CLIENT_1 | 21 +-- CLIENT_1 |
| 22 | +-- <content of the first AAR file> | 22 | +-- <content of the first AAR file> |
| 23 +-- CLIENT_2 | 23 +-- CLIENT_2 |
| 24 +-- etc. | 24 +-- etc. |
| 25 | 25 |
| 26 The output will follow the same structure, with fewer resource files, in the | 26 The output will follow the same structure, with fewer resource files, in the |
| 27 provided output directory. | 27 provided output directory. |
| 28 ''' | 28 ''' |
| 29 | 29 |
| 30 import argparse | 30 import argparse |
| 31 import datetime | |
| 31 import glob | 32 import glob |
| 32 import itertools | 33 import itertools |
| 33 import os | 34 import os |
| 34 import shutil | 35 import shutil |
| 35 import stat | 36 import stat |
| 36 import sys | 37 import sys |
| 37 import tempfile | 38 import tempfile |
| 38 import zipfile | 39 import zipfile |
| 39 | 40 |
| 40 sys.path.append(os.path.join(os.path.dirname(__file__), os.pardir)) | 41 sys.path.append(os.path.join(os.path.dirname(__file__), os.pardir)) |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 53 '--repository', | 54 '--repository', |
| 54 help=('the Google Play services repository ' | 55 help=('the Google Play services repository ' |
| 55 'location'), | 56 'location'), |
| 56 required=True, | 57 required=True, |
| 57 metavar='FILE') | 58 metavar='FILE') |
| 58 required_args.add_argument('-o', | 59 required_args.add_argument('-o', |
| 59 '--out-dir', | 60 '--out-dir', |
| 60 help='the output directory', | 61 help='the output directory', |
| 61 required=True, | 62 required=True, |
| 62 metavar='FILE') | 63 metavar='FILE') |
| 64 required_args.add_argument('-g', | |
| 65 '--gni-out-file', | |
| 66 help='the GN output file', | |
| 67 required=True, | |
| 68 metavar='FILE') | |
| 63 required_args.add_argument('-c', | 69 required_args.add_argument('-c', |
| 64 '--config-file', | 70 '--config-file', |
| 65 help='the config file path', | 71 help='the config file path', |
| 66 required=True, | 72 required=True, |
| 67 metavar='FILE') | 73 metavar='FILE') |
| 68 parser.add_argument('--config-help', | 74 parser.add_argument('--config-help', |
| 69 action='custom_help', | 75 action='custom_help', |
| 70 custom_help_text=utils.ConfigParser.__doc__, | 76 custom_help_text=utils.ConfigParser.__doc__, |
| 71 help='show the configuration file format help') | 77 help='show the configuration file format help') |
| 72 | 78 |
| 73 args = parser.parse_args() | 79 args = parser.parse_args() |
| 74 | 80 |
| 75 return ProcessGooglePlayServices(args.repository, | 81 return ProcessGooglePlayServices(args.repository, |
| 76 args.out_dir, | 82 args.out_dir, |
| 83 args.gni_out_file, | |
| 77 args.config_file) | 84 args.config_file) |
| 78 | 85 |
| 79 | 86 |
| 80 def ProcessGooglePlayServices(repo, out_dir, config_path): | 87 def ProcessGooglePlayServices(repo, out_dir, gni_out_file, config_path): |
| 81 config = utils.ConfigParser(config_path) | 88 config = utils.ConfigParser(config_path) |
| 82 | 89 |
| 83 tmp_root = tempfile.mkdtemp() | 90 tmp_root = tempfile.mkdtemp() |
| 84 try: | 91 try: |
| 85 tmp_paths = _SetupTempDir(tmp_root) | 92 tmp_paths = _SetupTempDir(tmp_root) |
| 86 _ImportFromExtractedRepo(config, tmp_paths, repo) | 93 _ImportFromExtractedRepo(config, tmp_paths, repo) |
| 87 _ProcessResources(config, tmp_paths, repo) | 94 _ProcessResources(config, tmp_paths, repo) |
| 88 _CopyToOutput(tmp_paths, out_dir) | 95 _CopyToOutput(tmp_paths, out_dir) |
| 96 _EnumerateProguardFiles(gni_out_file, out_dir) | |
| 89 _UpdateVersionInConfig(config, tmp_paths) | 97 _UpdateVersionInConfig(config, tmp_paths) |
| 90 finally: | 98 finally: |
| 91 shutil.rmtree(tmp_root) | 99 shutil.rmtree(tmp_root) |
| 92 | 100 |
| 93 return 0 | 101 return 0 |
| 94 | 102 |
| 95 | 103 |
| 96 def _SetupTempDir(tmp_root): | 104 def _SetupTempDir(tmp_root): |
| 97 tmp_paths = { | 105 tmp_paths = { |
| 98 'root': tmp_root, | 106 'root': tmp_root, |
| (...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 180 shutil.copy(os.path.join(repo, whitelisted_file), rebased_res) | 188 shutil.copy(os.path.join(repo, whitelisted_file), rebased_res) |
| 181 finally: | 189 finally: |
| 182 _MakeWritable(rebased_res) | 190 _MakeWritable(rebased_res) |
| 183 | 191 |
| 184 | 192 |
| 185 def _CopyToOutput(tmp_paths, out_dir): | 193 def _CopyToOutput(tmp_paths, out_dir): |
| 186 shutil.rmtree(out_dir, ignore_errors=True) | 194 shutil.rmtree(out_dir, ignore_errors=True) |
| 187 shutil.copytree(tmp_paths['imported_clients'], out_dir) | 195 shutil.copytree(tmp_paths['imported_clients'], out_dir) |
| 188 | 196 |
| 189 | 197 |
| 198 gni_template = '''\ | |
| 199 # Copyright {year} The Chromium Authors. All rights reserved. | |
|
Maria
2017/04/19 18:20:22
not sure that year should be computed. Generally c
paulmiller
2017/04/19 18:34:27
Done.
| |
| 200 # Use of this source code is governed by a BSD-style license that can be | |
| 201 # found in the LICENSE file. | |
| 202 | |
| 203 # This file generated by {script} | |
| 204 gms_proguard_configs = [ | |
| 205 {body} | |
| 206 ] | |
| 207 ''' | |
| 208 | |
| 209 # Write a GN file containing a list of each GMS client's proguard file (if any). | |
| 210 def _EnumerateProguardFiles(gni_path, out_dir): | |
| 211 gni_dir = os.path.dirname(gni_path) | |
| 212 | |
| 213 gni_lines = [] | |
| 214 for client_dir in os.listdir(out_dir): | |
| 215 proguard_path = os.path.join( | |
| 216 out_dir, client_dir, 'proguard.txt') | |
| 217 if os.path.exists(os.path.dirname(proguard_path)): | |
| 218 relative = os.path.relpath(proguard_path, gni_dir) | |
| 219 gni_lines.append(' "' + relative + '",') | |
| 220 gni_lines.sort() | |
| 221 | |
| 222 gni_text = gni_template.format( | |
| 223 year=datetime.datetime.now().year, | |
| 224 script=os.path.relpath(sys.argv[0], gni_dir), | |
| 225 body='\n'.join(gni_lines)) | |
| 226 | |
| 227 with open(gni_path, 'w') as gni_file: | |
| 228 gni_file.write(gni_text) | |
| 229 | |
| 230 | |
| 190 def _UpdateVersionInConfig(config, tmp_paths): | 231 def _UpdateVersionInConfig(config, tmp_paths): |
| 191 version_xml_path = os.path.join(tmp_paths['imported_clients'], | 232 version_xml_path = os.path.join(tmp_paths['imported_clients'], |
| 192 config.version_xml_path) | 233 config.version_xml_path) |
| 193 play_services_full_version = utils.GetVersionNumberFromLibraryResources( | 234 play_services_full_version = utils.GetVersionNumberFromLibraryResources( |
| 194 version_xml_path) | 235 version_xml_path) |
| 195 config.UpdateVersionNumber(play_services_full_version) | 236 config.UpdateVersionNumber(play_services_full_version) |
| 196 | 237 |
| 197 | 238 |
| 198 def _ExtractAll(zip_path, out_path): | 239 def _ExtractAll(zip_path, out_path): |
| 199 with zipfile.ZipFile(zip_path, 'r') as zip_file: | 240 with zipfile.ZipFile(zip_path, 'r') as zip_file: |
| 200 zip_file.extractall(out_path) | 241 zip_file.extractall(out_path) |
| 201 | 242 |
| 202 if __name__ == '__main__': | 243 if __name__ == '__main__': |
| 203 sys.exit(main()) | 244 sys.exit(main()) |
| OLD | NEW |