OLD | NEW |
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # | 2 # |
3 # Copyright 2013 The Chromium Authors. All rights reserved. | 3 # Copyright 2013 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 """An Ant wrapper that suppresses useless Ant output. | 7 """An Ant wrapper that suppresses useless Ant output. |
8 | 8 |
9 Ant build scripts output "BUILD SUCCESSFUL" and build timing at the end of | 9 Ant build scripts output "BUILD SUCCESSFUL" and build timing at the end of |
10 every build. In the Android build, this just adds a lot of useless noise to the | 10 every build. In the Android build, this just adds a lot of useless noise to the |
11 build output. This script forwards its arguments to ant, and prints Ant's | 11 build output. This script forwards its arguments to ant, and prints Ant's |
12 output up until the BUILD SUCCESSFUL line. | 12 output up until the BUILD SUCCESSFUL line. |
| 13 |
| 14 Also, when a command fails, this script will re-run that ant command with the |
| 15 '-verbose' argument so that the failure is easier to debug. |
13 """ | 16 """ |
14 | 17 |
15 import sys | 18 import sys |
16 import traceback | 19 import traceback |
17 | 20 |
18 from util import build_utils | 21 from util import build_utils |
19 | 22 |
20 | 23 |
21 def main(argv): | 24 def main(argv): |
22 try: | 25 try: |
23 stdout = build_utils.CheckOutput(['ant'] + argv[1:]) | 26 args = argv[1:] |
| 27 stdout = build_utils.CheckOutput(['ant'] + args) |
24 except build_utils.CalledProcessError as e: | 28 except build_utils.CalledProcessError as e: |
25 traceback.print_exc() | 29 # It is very difficult to diagnose ant failures without the '-verbose' |
26 if '-quiet' in e.args: | 30 # argument. So, when an ant command fails, re-run it with '-verbose' so that |
27 sys.stderr.write('Tip: run the ant command above without the -quiet flag ' | 31 # the cause of the failure is easier to identify. |
28 'to see more details on the error\n') | 32 verbose_args = ['-verbose'] + [a for a in argv[1:] if a != '-quiet'] |
29 sys.exit(1) | 33 try: |
| 34 stdout = build_utils.CheckOutput(['ant'] + verbose_args) |
| 35 except build_utils.CalledProcessError as e: |
| 36 traceback.print_exc() |
| 37 sys.exit(1) |
| 38 |
| 39 # If this did sys.exit(1), building again would succeed (which would be |
| 40 # awkward). Instead, just print a big warning. |
| 41 build_util.PrintBigWarning( |
| 42 'This is unexpected. `ant ' + ' '.join(args) + '` failed.' + |
| 43 'But, running `ant ' + ' '.join(verbose_args) + '` passed.') |
| 44 |
30 stdout = stdout.strip().split('\n') | 45 stdout = stdout.strip().split('\n') |
31 for line in stdout: | 46 for line in stdout: |
32 if line.strip() == 'BUILD SUCCESSFUL': | 47 if line.strip() == 'BUILD SUCCESSFUL': |
33 break | 48 break |
34 print line | 49 print line |
35 | 50 |
36 | 51 |
37 if __name__ == '__main__': | 52 if __name__ == '__main__': |
38 sys.exit(main(sys.argv)) | 53 sys.exit(main(sys.argv)) |
OLD | NEW |