electron/script/bootstrap.py

263 lines
8.9 KiB
Python
Raw Normal View History

2013-06-19 06:32:41 +00:00
#!/usr/bin/env python
2013-04-12 01:46:58 +00:00
2013-06-19 06:32:41 +00:00
import argparse
import os
2015-07-03 02:01:44 +00:00
import subprocess
2013-06-19 06:32:41 +00:00
import sys
2013-04-12 01:46:58 +00:00
from lib.config import LIBCHROMIUMCONTENT_COMMIT, BASE_URL, PLATFORM, \
2015-04-11 10:26:15 +00:00
enable_verbose_mode, is_verbose_mode, get_target_arch
2016-05-24 17:27:46 +00:00
from lib.util import execute_stdout, get_electron_version, scoped_cwd
2013-04-12 01:46:58 +00:00
2013-06-19 06:32:41 +00:00
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
VENDOR_DIR = os.path.join(SOURCE_ROOT, 'vendor')
PYTHON_26_URL = 'https://chromium.googlesource.com/chromium/deps/python_26'
2015-07-02 14:34:05 +00:00
if os.environ.has_key('CI'):
NPM = os.path.join(SOURCE_ROOT, 'node_modules', '.bin', 'npm')
else:
NPM = 'npm'
if sys.platform in ['win32', 'cygwin']:
NPM += '.cmd'
2013-04-12 01:46:58 +00:00
2013-06-19 06:32:41 +00:00
def main():
os.chdir(SOURCE_ROOT)
2013-04-12 01:46:58 +00:00
2013-06-19 06:32:41 +00:00
args = parse_args()
defines = args_to_defines(args)
if not args.yes and PLATFORM != 'win32':
check_root()
if args.verbose:
2014-12-08 17:03:48 +00:00
enable_verbose_mode()
if sys.platform == 'cygwin':
update_win32_python()
update_submodules()
2016-05-02 07:04:50 +00:00
libcc_source_path = args.libcc_source_path
libcc_shared_library_path = args.libcc_shared_library_path
libcc_static_library_path = args.libcc_static_library_path
# Redirect to use local libchromiumcontent build.
if args.build_libchromiumcontent:
2016-05-02 12:15:10 +00:00
build_libchromiumcontent(args.verbose, args.target_arch, defines)
2016-05-02 07:04:50 +00:00
dist_dir = os.path.join(SOURCE_ROOT, 'vendor', 'brightray', 'vendor',
'libchromiumcontent', 'dist', 'main')
libcc_source_path = os.path.join(dist_dir, 'src')
libcc_shared_library_path = os.path.join(dist_dir, 'shared_library')
libcc_static_library_path = os.path.join(dist_dir, 'static_library')
2016-05-03 00:38:15 +00:00
if PLATFORM != 'win32':
2016-05-19 01:14:57 +00:00
if not args.disable_clang and args.clang_dir == '':
# Download prebuilt clang binaries.
update_clang()
2015-07-01 06:27:15 +00:00
2015-07-03 14:52:26 +00:00
setup_python_libs()
update_node_modules('.')
bootstrap_brightray(args.dev, args.url, args.target_arch,
2016-05-02 07:04:50 +00:00
libcc_source_path, libcc_shared_library_path,
libcc_static_library_path)
if PLATFORM == 'linux':
2016-03-08 15:05:32 +00:00
download_sysroot(args.target_arch)
2015-07-01 09:22:40 +00:00
create_chrome_version_h()
touch_config_gypi()
2016-05-14 14:11:13 +00:00
run_update(defines, args.disable_clang, args.clang_dir)
2015-04-12 13:55:17 +00:00
update_electron_modules('spec', args.target_arch)
2013-04-12 01:46:58 +00:00
2014-08-12 12:28:18 +00:00
2013-06-19 06:32:41 +00:00
def parse_args():
parser = argparse.ArgumentParser(description='Bootstrap this project')
parser.add_argument('-u', '--url',
2013-06-19 06:32:41 +00:00
help='The base URL from which to download '
'libchromiumcontent (i.e., the URL you passed to '
'libchromiumcontent\'s script/upload script',
default=BASE_URL,
required=False)
parser.add_argument('-v', '--verbose',
action='store_true',
help='Prints the output of the subprocesses')
parser.add_argument('-d', '--dev', action='store_true',
help='Do not download static_library build')
parser.add_argument('-y', '--yes', '--assume-yes',
action='store_true',
help='Run non-interactively by assuming "yes" to all ' \
'prompts.')
2015-04-11 10:26:15 +00:00
parser.add_argument('--target_arch', default=get_target_arch(),
help='Manually specify the arch to build for')
parser.add_argument('--clang_dir', default='', help='Path to clang binaries')
parser.add_argument('--disable_clang', action='store_true',
help='Use compilers other than clang for building')
2016-05-02 07:04:50 +00:00
parser.add_argument('--build_libchromiumcontent', action='store_true',
help='Build local version of libchromiumcontent')
parser.add_argument('--libcc_source_path', required=False,
help='The source path of libchromiumcontent. ' \
'NOTE: All options of libchromiumcontent are ' \
'required OR let electron choose it')
parser.add_argument('--libcc_shared_library_path', required=False,
help='The shared library path of libchromiumcontent.')
parser.add_argument('--libcc_static_library_path', required=False,
help='The static library path of libchromiumcontent.')
2013-06-19 06:32:41 +00:00
return parser.parse_args()
2013-04-12 01:46:58 +00:00
def args_to_defines(args):
defines = ''
if args.disable_clang:
defines += ' clang=0'
if args.clang_dir:
defines += ' make_clang_dir=' + args.clang_dir
defines += ' clang_use_chrome_plugins=0'
return defines
def check_root():
if os.geteuid() == 0:
print "We suggest not running this as root, unless you're really sure."
choice = raw_input("Do you want to continue? [y/N]: ")
if choice not in ('y', 'Y'):
sys.exit(0)
2014-08-12 12:28:18 +00:00
2013-06-19 06:32:41 +00:00
def update_submodules():
2016-05-15 01:33:23 +00:00
execute_stdout(['git', 'submodule', 'sync', '--recursive'])
execute_stdout(['git', 'submodule', 'update', '--init', '--recursive'])
2013-06-19 06:32:41 +00:00
2015-07-03 14:52:26 +00:00
def setup_python_libs():
for lib in ('requests', 'boto'):
with scoped_cwd(os.path.join(VENDOR_DIR, lib)):
execute_stdout([sys.executable, 'setup.py', 'build'])
2015-07-03 06:23:42 +00:00
def bootstrap_brightray(is_dev, url, target_arch, libcc_source_path,
libcc_shared_library_path,
libcc_static_library_path):
2013-06-19 06:32:41 +00:00
bootstrap = os.path.join(VENDOR_DIR, 'brightray', 'script', 'bootstrap')
args = [
'--commit', LIBCHROMIUMCONTENT_COMMIT,
'--target_arch', target_arch,
url
]
if is_dev:
args = ['--dev'] + args
if (libcc_source_path != None and
libcc_shared_library_path != None and
libcc_static_library_path != None):
args += ['--libcc_source_path', libcc_source_path,
'--libcc_shared_library_path', libcc_shared_library_path,
'--libcc_static_library_path', libcc_static_library_path]
execute_stdout([sys.executable, bootstrap] + args)
2013-06-19 06:32:41 +00:00
def set_clang_env(env):
llvm_dir = os.path.join(SOURCE_ROOT, 'vendor', 'llvm-build',
'Release+Asserts', 'bin')
env['CC'] = os.path.join(llvm_dir, 'clang')
env['CXX'] = os.path.join(llvm_dir, 'clang++')
2015-04-12 05:15:11 +00:00
def update_node_modules(dirname, env=None):
if env is None:
2016-05-02 12:38:17 +00:00
env = os.environ.copy()
if PLATFORM == 'linux':
# Use prebuilt clang for building native modules.
set_clang_env(env)
env['npm_config_clang'] = '1'
2014-04-28 02:05:22 +00:00
with scoped_cwd(dirname):
args = [NPM, 'install']
2014-12-08 17:03:48 +00:00
if is_verbose_mode():
2015-07-03 06:23:42 +00:00
args += ['--verbose']
# Ignore npm install errors when running in CI.
if os.environ.has_key('CI'):
try:
execute_stdout(args, env)
2015-07-03 02:01:44 +00:00
except subprocess.CalledProcessError:
pass
else:
execute_stdout(args, env)
2015-04-12 13:55:17 +00:00
def update_electron_modules(dirname, target_arch):
env = os.environ.copy()
env['npm_config_arch'] = target_arch
2016-05-24 17:27:46 +00:00
env['npm_config_target'] = get_electron_version()
env['npm_config_disturl'] = 'https://atom.io/download/atom-shell'
update_node_modules(dirname, env)
def update_win32_python():
with scoped_cwd(VENDOR_DIR):
if not os.path.exists('python_26'):
execute_stdout(['git', 'clone', PYTHON_26_URL])
2015-07-01 06:27:15 +00:00
def build_libchromiumcontent(verbose, target_arch, defines):
2016-05-02 07:04:50 +00:00
args = [os.path.join(SOURCE_ROOT, 'script', 'build-libchromiumcontent.py')]
2016-05-02 07:38:58 +00:00
if verbose:
2016-05-02 07:04:50 +00:00
args += ['-v']
if defines:
args += ['--defines', defines]
2016-05-02 07:04:50 +00:00
execute_stdout(args + ['--target_arch', target_arch])
2015-07-01 06:27:15 +00:00
def update_clang():
execute_stdout([os.path.join(SOURCE_ROOT, 'script', 'update-clang.sh')])
2016-03-08 15:05:32 +00:00
def download_sysroot(target_arch):
if target_arch == 'ia32':
2016-03-10 11:54:45 +00:00
target_arch = 'i386'
2016-03-08 15:05:32 +00:00
if target_arch == 'x64':
target_arch = 'amd64'
2016-04-07 06:45:20 +00:00
execute_stdout([sys.executable,
os.path.join(SOURCE_ROOT, 'script', 'install-sysroot.py'),
2016-03-08 15:05:32 +00:00
'--arch', target_arch])
2015-07-01 09:22:40 +00:00
def create_chrome_version_h():
version_file = os.path.join(SOURCE_ROOT, 'vendor', 'brightray', 'vendor',
'libchromiumcontent', 'VERSION')
target_file = os.path.join(SOURCE_ROOT, 'atom', 'common', 'chrome_version.h')
template_file = os.path.join(SOURCE_ROOT, 'script', 'chrome_version.h.in')
with open(version_file, 'r') as f:
version = f.read()
with open(template_file, 'r') as f:
template = f.read()
content = template.replace('{PLACEHOLDER}', version.strip())
# We update the file only if the content has changed (ignoring line ending
# differences).
should_write = True
if os.path.isfile(target_file):
with open(target_file, 'r') as f:
should_write = f.read().replace('r', '') != content.replace('r', '')
if should_write:
with open(target_file, 'w') as f:
f.write(content)
def touch_config_gypi():
config_gypi = os.path.join(SOURCE_ROOT, 'vendor', 'node', 'config.gypi')
with open(config_gypi, 'w+') as f:
2015-12-08 03:14:30 +00:00
content = "\n{'variables':{}}"
if f.read() != content:
f.write(content)
2016-05-14 14:11:13 +00:00
def run_update(defines, disable_clang, clang_dir):
env = os.environ.copy()
if not disable_clang and clang_dir == '':
# Build with prebuilt clang.
set_clang_env(env)
2013-06-24 07:24:30 +00:00
update = os.path.join(SOURCE_ROOT, 'script', 'update.py')
2016-05-14 14:11:13 +00:00
execute_stdout([sys.executable, update, '--defines', defines], env)
2013-06-19 06:32:41 +00:00
if __name__ == '__main__':
sys.exit(main())