Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # | 2 # |
| 3 # Copyright 2016 The Chromium Authors. All rights reserved. | 3 # Copyright 2017 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 import argparse | 7 import argparse |
| 8 import os | 8 import os |
| 9 import shutil | 9 import shutil |
| 10 import sys | 10 import sys |
| 11 import tempfile | 11 import tempfile |
| 12 | 12 |
| 13 from util import build_utils | 13 from util import build_utils |
| 14 | 14 |
| 15 | 15 |
| 16 _SRC_ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), | 16 _SRC_ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), |
| 17 '..', '..', '..')) | 17 '..', '..', '..')) |
| 18 _RETROLAMBDA_JAR_PATH = os.path.normpath(os.path.join( | 18 _DESUGAR_JAR_PATH = os.path.normpath(os.path.join( |
| 19 _SRC_ROOT, 'third_party', 'retrolambda', 'retrolambda-2.5.1.jar')) | 19 _SRC_ROOT, 'third_party', 'desugar', 'Desugar.jar')) |
| 20 | 20 |
| 21 | 21 |
| 22 def _OnStaleMd5(input_jar, output_jar, classpath, android_sdk_jar): | 22 def _OnStaleMd5(input_jar, output_jar, classpath, android_sdk_jar, |
| 23 with build_utils.TempDir() as temp_dir: | 23 bootclasspath): |
| 24 build_utils.ExtractAll(input_jar, path=temp_dir) | 24 cmd = [ |
| 25 cmd = [ | 25 'java', |
| 26 'java', | 26 '-jar', |
| 27 '-Dretrolambda.inputDir=' + temp_dir, | 27 _DESUGAR_JAR_PATH, |
| 28 '-Dretrolambda.classpath=' + | 28 '--input', |
| 29 ':'.join([temp_dir] + classpath + [android_sdk_jar]), | 29 input_jar, |
| 30 '-javaagent:' + _RETROLAMBDA_JAR_PATH, | 30 '--bootclasspath_entry', |
| 31 '-jar', | 31 bootclasspath, |
| 32 _RETROLAMBDA_JAR_PATH, | 32 '--output', |
| 33 ] | 33 output_jar, |
| 34 | 34 '--desugar_try_with_resources_if_needed=false', |
| 35 build_utils.CheckOutput(cmd, print_stdout=False) | 35 ] |
| 36 build_utils.ZipDir(output_jar + '.tmp', temp_dir) | 36 for path in sorted(classpath) + [android_sdk_jar]: |
|
agrieve
2017/07/20 00:26:51
shouldn't sort the classpath. Order could matter.
F
2017/07/20 17:30:56
Done. Thanks! I misunderstood "ordered" in the par
| |
| 37 shutil.move(output_jar + '.tmp', output_jar) | 37 cmd += ['--classpath_entry', path] |
| 38 build_utils.CheckOutput(cmd, print_stdout=False) | |
| 38 | 39 |
| 39 | 40 |
| 40 def main(): | 41 def main(): |
| 41 args = build_utils.ExpandFileArgs(sys.argv[1:]) | 42 args = build_utils.ExpandFileArgs(sys.argv[1:]) |
| 42 parser = argparse.ArgumentParser() | 43 parser = argparse.ArgumentParser() |
| 43 build_utils.AddDepfileOption(parser) | 44 build_utils.AddDepfileOption(parser) |
| 44 parser.add_argument('--input-jar', required=True, | 45 parser.add_argument('--input-jar', required=True, |
| 45 help='Jar input path to include .class files from.') | 46 help='Jar input path to include .class files from.') |
| 46 parser.add_argument('--output-jar', required=True, | 47 parser.add_argument('--output-jar', required=True, |
| 47 help='Jar output path.') | 48 help='Jar output path.') |
| 48 parser.add_argument('--classpath', required=True, | 49 parser.add_argument('--classpath', required=True, |
| 49 help='Classpath.') | 50 help='Classpath.') |
| 50 parser.add_argument('--android-sdk-jar', required=True, | 51 parser.add_argument('--android-sdk-jar', required=True, |
| 51 help='Android sdk jar path.') | 52 help='Android sdk jar path.') |
| 53 parser.add_argument('--bootclasspath', required=True, | |
| 54 help='Javac bootclasspath.') | |
| 52 options = parser.parse_args(args) | 55 options = parser.parse_args(args) |
| 53 | 56 |
| 54 options.classpath = build_utils.ParseGnList(options.classpath) | 57 options.classpath = build_utils.ParseGnList(options.classpath) |
| 55 input_paths = options.classpath + [options.input_jar] | 58 input_paths = options.classpath + [options.input_jar, |
| 59 options.android_sdk_jar, | |
| 60 options.bootclasspath] | |
|
agrieve
2017/07/20 00:26:51
I don't think this is quite right. There's no reas
F
2017/07/20 17:30:56
Done.
| |
| 56 output_paths = [options.output_jar] | 61 output_paths = [options.output_jar] |
| 57 | 62 |
| 58 build_utils.CallAndWriteDepfileIfStale( | 63 build_utils.CallAndWriteDepfileIfStale( |
| 59 lambda: _OnStaleMd5(options.input_jar, options.output_jar, | 64 lambda: _OnStaleMd5(options.input_jar, options.output_jar, |
| 60 options.classpath, options.android_sdk_jar), | 65 options.classpath, options.android_sdk_jar, |
| 66 options.bootclasspath), | |
| 61 options, | 67 options, |
| 62 input_paths=input_paths, | 68 input_paths=input_paths, |
| 63 input_strings=[], | 69 input_strings=[], |
| 64 output_paths=output_paths) | 70 output_paths=output_paths, |
| 71 depfile_deps=input_paths) | |
| 65 | 72 |
| 66 | 73 |
| 67 if __name__ == '__main__': | 74 if __name__ == '__main__': |
| 68 sys.exit(main()) | 75 sys.exit(main()) |
| OLD | NEW |