Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(289)

Side by Side Diff: syzygy/integration_tests/make_integration_tests_clang.py

Issue 2946063002: Python script to compile and link the integration tests using llvm's clang-cl (Closed)
Patch Set: Response to reviewer comments. Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « syzygy/integration_tests/integration_tests.gyp ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 #!/usr/bin/env python
2 # Copyright 2017 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file.
Sébastien Marchand 2017/06/22 19:44:48 Add a comment to describe what this script does, e
njanevsk 2017/06/22 21:16:32 Done.
5
Sébastien Marchand 2017/06/22 19:44:48 Add a BL here. Basically each "section" is separa
njanevsk 2017/06/22 21:16:33 Done.
6 import optparse
7 import os
8 import re
9 import subprocess
10 import sys
11
Sébastien Marchand 2017/06/22 19:34:17 Add an extra BL here.
njanevsk 2017/06/22 21:16:32 Done.
12 _SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__))
13 _SRC_DIR = os.path.abspath(os.path.join(os.path.join(_SCRIPT_DIR, os.pardir),
Sébastien Marchand 2017/06/22 19:34:17 you can do os.path.abspath(os.path.join(_SCRIPT_DI
njanevsk 2017/06/22 21:16:33 Done.
14 os.pardir))
Sébastien Marchand 2017/06/22 19:34:17 Indent at +4.
njanevsk 2017/06/22 21:16:32 Done.
15 _CLANG_PATH = (_SRC_DIR,
Sébastien Marchand 2017/06/22 19:34:16 I'd call this _CLANG_CL_PATH
njanevsk 2017/06/22 21:16:32 Done.
16 "/third_party/llvm-build/Release+Asserts/bin/clang-cl.exe")
17
Sébastien Marchand 2017/06/22 19:34:17 Add an extra BL here.
njanevsk 2017/06/22 21:16:32 Done.
18 def compile(clang_path, source_files, src_dir):
19 """ Only compiles the integration tests but does not link.
Sébastien Marchand 2017/06/22 19:34:17 Remove the space before "Only", also I'll just say
njanevsk 2017/06/22 21:16:32 Done.
20
Sébastien Marchand 2017/06/22 19:34:17 Remove one of these 2 BLs.
njanevsk 2017/06/22 21:16:33 Done.
21
22 Only compiles the files and isntruments them with LLVM's Asan but does not
23 link them. The linking is done separately in the method link.
24
25 Args:
26 clang_path: Path to the clang-cl compiler in the syzygy project.
27 source_files: The source files to be compiled.
28 src_dir: The repository where the syzgy src is located.
29 """
30 compiler_flags = ['-c',
Sébastien Marchand 2017/06/22 19:34:17 Nit, I prefer this form: foo = [ 'bar', 'b
njanevsk 2017/06/22 21:16:32 Done.
31 '-fsanitize=address',
32 '-mllvm',
33 '-asan-instrumentation-with-call-threshold=0',
34 '-mllvm',
35 '-asan-stack=0',
36 '-DUNICODE',
37 '-D_UNICODE',
38 '-DNOMINMAX',
39 '-D_CRT_SECURE_NO_WARNINGS',
40 '-I' + src_dir]
41
42 compile_command = [clang_path]
43 compile_command.extend(compiler_flags)
44 compile_command.extend(source_files)
45
46 ret = subprocess.call(compile_command)
47 if ret != 0:
48 print "Failed compiling the integration_tests using clang-cl"
49 return ret
50
Sébastien Marchand 2017/06/22 19:44:48 2 BLs between each function :)
njanevsk 2017/06/22 21:16:32 Done.
51 def link(clang_path, source_files, build_dir):
52 """ Links the object files and produces the integration_tests_clang_dll.dll.
53
Sébastien Marchand 2017/06/22 19:34:17 Remove one of these BLs.
njanevsk 2017/06/22 21:16:33 Done.
54
55 Links the object files and produces the dll. The object files have to be
56 produced by the compile method above.
57
58 Args:
59 clang_path: Path to the clang-cl compiler in the syzygy project.
60 source_files: The source file names which are converted to obj filenames.
61 build_dir: The directory where to produce the linked dll.
62 """
63 object_files = ([os.path.splitext(filename)[0] +
64 ".o" for filename in source_files])
Sébastien Marchand 2017/06/22 19:34:17 Indent +2. When you continue a line over the next
njanevsk 2017/06/22 21:16:32 Done.
65
66 compiler_controlled_linker_flags = ['-o',
67 (build_dir,
Sébastien Marchand 2017/06/22 19:34:17 Why the parenthesis? Should you use os.path.join h
njanevsk 2017/06/22 21:16:33 To join the two. I tried os.path.join but I get an
Sébastien Marchand 2017/06/23 18:01:54 os.path.join handles '..', you should use it.
68 '\integration_tests_clang_dll.dll')]
69
70 linker_flags = ['/link',
71 '/dll',
72 build_dir + '\export_dll.dll.lib',
73 build_dir + '\syzyasan_rtl.dll.lib',
74 '-defaultlib:libcmt']
75
76 linker_command = [clang_path, '-m32']
77 linker_command.extend(object_files)
78 linker_command.extend(compiler_controlled_linker_flags)
79 linker_command.extend(linker_flags)
80 ret = subprocess.call(linker_command)
81
82 if ret != 0:
83 print "Failed to link the integration_tests using clang-cl"
84
85 def main():
86 parser = optparse.OptionParser(usage='%prog [options]')
87 parser.add_option('--build-dir', help='Syzygy build directory.')
Sébastien Marchand 2017/06/22 19:44:48 help="Path to the build directory"? There's a dire
njanevsk 2017/06/22 21:16:32 To the Release directory not the build directory.
Sébastien Marchand 2017/06/23 18:01:53 You also want this to work in debug :), let's just
88 parser.add_option('--input-files', help='files to be compiled and linked')
89
90 options, _ = parser.parse_args()
91
92 if not options.build_dir:
93 parser.error('--build-dir is required')
94 if not options.input_files:
95 parser.error('--input-files is required')
96
97 source_files = re.findall(r'\b(\w+.cc)\b', options.input_files)
Sébastien Marchand 2017/06/22 19:34:17 using a Regex is overkill, you can use glob: https
Sébastien Marchand 2017/06/22 19:44:48 And as discussed in a previous patchset we should
98 ret = compile(_CLANG_PATH, source_files, _SRC_DIR)
99 if ret == 0:
100 link(_CLANG_PATH, source_files, options.build_dir)
101 else:
102 print "Compilation of integration_tests_clang_dll failed."
103 print "Skipping link step."
Sébastien Marchand 2017/06/22 19:34:17 You should also return something !0 on failure so
njanevsk 2017/06/22 21:16:32 Done.
104
105 if __name__ == '__main__':
106 sys.exit(main())
OLDNEW
« no previous file with comments | « syzygy/integration_tests/integration_tests.gyp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698