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 |