1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
#!/usr/bin/python
# Copyright 2016 Google Inc.
#
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""
Script to build the command buffer shared library and copy it to Skia tree
"""
import argparse
import os
import shlex
import shutil
import subprocess
import sys
def main():
parser = argparse.ArgumentParser(description=('Builds command_buffer_gles2 '
'library and copies it'))
parser.add_argument('-c', '--chrome-dir', required=True, help=
'path to Chromium checkout (directory containing .gclient)')
parser.add_argument('-o', '--output-dir', required=True,
help='path to copy the command buffer shared library to')
parser.add_argument('--make-output-dir', default=False, action='store_true',
help='Makes the output directory if it does not already exist.')
parser.add_argument('-f', '--fetch', action='store_true', default=False,
help=('Create Chromium src directory and fetch chromium checkout (if '
'directory does not already exist)'))
parser.add_argument('--chrome-build-type', default='Release',
help='Type of build for the command buffer (e.g. Debug or Release)')
parser.add_argument('--extra-ninja-args', default='',
help=('Extra arguments to pass to ninja when building the command '
'buffer shared library'))
parser.add_argument('--chrome-revision', default='origin/lkgr',
help='Revision (hash, branch, tag) of Chromium to use.')
parser.add_argument('--no-sync', action='store_true', default=False,
help='Don\'t run git fetch or gclient sync in the Chromium tree')
args = parser.parse_args()
args.chrome_dir = os.path.abspath(args.chrome_dir)
args.output_dir = os.path.abspath(args.output_dir)
if os.path.isfile(args.chrome_dir):
sys.exit(args.chrome_dir + ' exists but is a file.')
if os.path.isfile(args.output_dir):
sys.exit(args.output_dir + ' exists but is a file.')
chrome_src_dir = os.path.join(args.chrome_dir, 'src')
if os.path.isfile(chrome_src_dir):
sys.exit(chrome_src_dir + ' exists but is a file.')
elif not os.path.isdir(chrome_src_dir):
if args.fetch:
if os.path.isdir(args.chrome_dir):
# If chrome_dir is a dir but chrome_src_dir does not exist we will only
# fetch into chrome_dir if it is empty.
if os.listdir(args.chrome_dir):
sys.exit(args.chrome_dir + ' is not a chromium checkout and is not '
'empty.')
else:
os.makedirs(args.chrome_dir)
if not os.path.isdir(args.chrome_dir):
sys.exit('Could not create ' + args.chrome_dir)
try:
subprocess.check_call(['fetch', 'chromium'], cwd=args.chrome_dir)
except subprocess.CalledProcessError as error:
sys.exit('Error (ret code: %s) calling "%s" in %s' % error.returncode,
error.cmd, args.chrome_dir)
if not os.path.isdir(chrome_src_dir):
sys.exit(chrome_src_dir + ' is not a directory.')
if os.path.isfile(args.output_dir):
sys.exit(args.output_dir + ' exists but is a file.')
elif not os.path.isdir(args.output_dir):
if args.make_output_dir:
os.makedirs(args.output_dir)
else:
sys.exit(args.output_dir + ' does not exist (specify --make-output-dir '
'to create).')
chrome_target_dir_rel = os.path.join('out', args.chrome_build_type)
# The command buffer shared library will have a different name on Linux,
# Mac, and Windows. Also, on Linux it will be in a 'lib' subdirectory and
# needs to be placed in a 'lib' subdirectory of the directory containing the
# Skia executable. Also, the name of the gclient executable we call out to has
# a .bat file extension on Windows.
platform = sys.platform
if platform == 'cygwin':
platform = 'win32'
shared_lib_name = 'libcommand_buffer_gles2.so'
shared_lib_subdir = 'lib'
gclient = 'gclient'
if platform == 'darwin':
shared_lib_name = 'libcommand_buffer_gles2.dylib'
shared_lib_subdir = ''
elif platform == 'win32':
shared_lib_name = 'command_buffer_gles2.dll'
shared_lib_subdir = ''
gclient = 'gclient.bat'
if not args.no_sync:
try:
subprocess.check_call(['git', 'fetch'], cwd=chrome_src_dir)
except subprocess.CalledProcessError as error:
sys.exit('Error (ret code: %s) calling "%s" in %s' % (error.returncode,
error.cmd, chrome_src_dir))
try:
subprocess.check_call(['git', 'checkout', args.chrome_revision],
cwd=chrome_src_dir)
except subprocess.CalledProcessError as error:
sys.exit('Error (ret code: %s) calling "%s" in %s' % (error.returncode,
error.cmd, chrome_src_dir))
try:
os.environ['GYP_GENERATORS'] = 'ninja'
subprocess.check_call([gclient, 'sync', '--reset', '--force'],
cwd=chrome_src_dir)
except subprocess.CalledProcessError as error:
sys.exit('Error (ret code: %s) calling "%s" in %s' % (error.returncode,
error.cmd, chrome_src_dir))
try:
subprocess.check_call(['ninja'] + shlex.split(args.extra_ninja_args) +
['-C', chrome_target_dir_rel, 'command_buffer_gles2'],
cwd=chrome_src_dir)
except subprocess.CalledProcessError as error:
sys.exit('Error (ret code: %s) calling "%s" in %s' % (error.returncode,
error.cmd, chrome_src_dir))
shared_lib_src_dir = os.path.join(chrome_src_dir, chrome_target_dir_rel,
shared_lib_subdir)
shared_lib_dst_dir = os.path.join(args.output_dir, shared_lib_subdir)
# Make the subdir for the dst if does not exist
if shared_lib_subdir and not os.path.isdir(shared_lib_dst_dir):
os.mkdir(shared_lib_dst_dir)
shared_lib_src = os.path.join(shared_lib_src_dir, shared_lib_name)
shared_lib_dst = os.path.join(shared_lib_dst_dir, shared_lib_name)
if not os.path.isfile(shared_lib_src):
sys.exit('Command buffer shared library not at expected location: ' +
shared_lib_src)
shutil.copy2(shared_lib_src, shared_lib_dst)
if not os.path.isfile(shared_lib_dst):
sys.exit('Command buffer library not copied to ' + shared_lib_dst)
print('Command buffer library copied to ' + shared_lib_dst)
if __name__ == '__main__':
main()
|