OLD | NEW |
---|---|
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # Copyright 2016 the V8 project authors. All rights reserved. | 2 # Copyright 2016 the V8 project authors. All rights reserved. |
3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
5 | 5 |
6 # CC/CXX wrapper script that excludes certain file patterns from coverage | 6 # CC/CXX wrapper script that excludes certain file patterns from coverage |
7 # instrumentation. | 7 # instrumentation. |
8 | 8 |
9 import re | 9 import re |
10 import subprocess | 10 import subprocess |
11 import sys | 11 import sys |
12 | 12 |
13 exclusions = [ | 13 exclusions = [ |
14 'buildtools', | |
14 'src/third_party', | 15 'src/third_party', |
15 'third_party', | 16 'third_party', |
16 'test', | 17 'test', |
17 'testing', | 18 'testing', |
18 ] | 19 ] |
19 | 20 |
21 def remove_if_exists(string_list, item): | |
22 try: | |
kjellander_chromium
2016/03/08 04:48:33
I guess it's faster to do
if item in string_list:
Michael Achenbach
2016/03/08 10:05:46
Done. Your way is definitely more readable and I d
tandrii(chromium)
2016/03/08 14:48:57
Your honor, I object! First,
try .. except ValueE
Michael Achenbach
2016/03/08 14:53:59
Right. Either way, I think it's hardly measurable
| |
23 string_list.remove(item) | |
24 except: | |
25 pass | |
26 | |
20 args = sys.argv[1:] | 27 args = sys.argv[1:] |
21 text = ' '.join(sys.argv[2:]) | 28 text = ' '.join(sys.argv[2:]) |
22 for exclusion in exclusions: | 29 for exclusion in exclusions: |
23 if re.search(r'\-o obj/%s[^ ]*\.o' % exclusion, text): | 30 if re.search(r'\-o obj/%s[^ ]*\.o' % exclusion, text): |
24 args.remove('-fprofile-arcs') | 31 remove_if_exists(args, '-fprofile-arcs') |
25 args.remove('-ftest-coverage') | 32 remove_if_exists(args, '-ftest-coverage') |
33 remove_if_exists(args, '-fsanitize-coverage=func') | |
34 remove_if_exists(args, '-fsanitize-coverage=bb') | |
35 remove_if_exists(args, '-fsanitize-coverage=edge') | |
26 break | 36 break |
27 | 37 |
28 sys.exit(subprocess.check_call(args)) | 38 sys.exit(subprocess.check_call(args)) |
OLD | NEW |