2022-04-12 11:21:55 +00:00
|
|
|
#!/usr/bin/env python3
|
2013-06-20 15:10:00 +00:00
|
|
|
|
2013-06-29 03:36:02 +00:00
|
|
|
import contextlib
|
2013-06-20 15:10:00 +00:00
|
|
|
import errno
|
2018-09-27 18:53:08 +00:00
|
|
|
import json
|
|
|
|
import os
|
2024-06-17 20:21:50 +00:00
|
|
|
import platform
|
2013-06-20 14:51:58 +00:00
|
|
|
import shutil
|
2013-06-21 02:32:57 +00:00
|
|
|
import subprocess
|
|
|
|
import sys
|
2023-11-01 14:20:32 +00:00
|
|
|
from urllib.request import urlopen
|
2013-06-20 15:23:22 +00:00
|
|
|
import zipfile
|
2013-06-20 14:51:58 +00:00
|
|
|
|
2022-10-25 06:44:43 +00:00
|
|
|
# from lib.config import is_verbose_mode
|
|
|
|
def is_verbose_mode():
|
|
|
|
return False
|
2013-06-20 14:51:58 +00:00
|
|
|
|
2019-06-24 17:18:04 +00:00
|
|
|
ELECTRON_DIR = os.path.abspath(
|
|
|
|
os.path.dirname(os.path.dirname(os.path.dirname(__file__)))
|
|
|
|
)
|
2020-11-09 21:57:53 +00:00
|
|
|
TS_NODE = os.path.join(ELECTRON_DIR, 'node_modules', '.bin', 'ts-node')
|
2018-10-08 20:19:40 +00:00
|
|
|
SRC_DIR = os.path.abspath(os.path.join(__file__, '..', '..', '..', '..'))
|
2016-08-01 02:00:19 +00:00
|
|
|
|
2017-05-25 21:53:42 +00:00
|
|
|
if sys.platform in ['win32', 'cygwin']:
|
2020-11-09 21:57:53 +00:00
|
|
|
TS_NODE += '.cmd'
|
2017-05-25 21:53:42 +00:00
|
|
|
|
2013-06-29 03:36:02 +00:00
|
|
|
@contextlib.contextmanager
|
|
|
|
def scoped_cwd(path):
|
|
|
|
cwd = os.getcwd()
|
|
|
|
os.chdir(path)
|
|
|
|
try:
|
|
|
|
yield
|
|
|
|
finally:
|
|
|
|
os.chdir(cwd)
|
|
|
|
|
|
|
|
|
2013-06-20 15:10:00 +00:00
|
|
|
def download(text, url, path):
|
2014-07-21 08:31:51 +00:00
|
|
|
safe_mkdir(os.path.dirname(path))
|
2024-03-21 13:48:23 +00:00
|
|
|
with open(path, 'wb') as local_file, urlopen(url) as web_file:
|
|
|
|
print(f"Downloading {url} to {path}")
|
2019-11-19 14:08:20 +00:00
|
|
|
info = web_file.info()
|
|
|
|
if hasattr(info, 'getheader'):
|
|
|
|
file_size = int(info.getheaders("Content-Length")[0])
|
|
|
|
else:
|
|
|
|
file_size = int(info.get("Content-Length")[0])
|
2013-06-20 15:10:00 +00:00
|
|
|
downloaded_size = 0
|
2019-03-27 01:22:54 +00:00
|
|
|
block_size = 4096
|
2013-06-20 14:51:58 +00:00
|
|
|
|
2018-07-30 22:34:38 +00:00
|
|
|
ci = os.environ.get('CI') is not None
|
2014-02-17 09:50:25 +00:00
|
|
|
|
2013-06-20 14:51:58 +00:00
|
|
|
while True:
|
|
|
|
buf = web_file.read(block_size)
|
|
|
|
if not buf:
|
|
|
|
break
|
|
|
|
|
|
|
|
downloaded_size += len(buf)
|
|
|
|
local_file.write(buf)
|
|
|
|
|
2014-02-17 09:50:25 +00:00
|
|
|
if not ci:
|
|
|
|
percent = downloaded_size * 100. / file_size
|
2024-03-21 13:48:23 +00:00
|
|
|
status = f"\r{text} {downloaded_size:10d} [{percent:3.1f}%]"
|
2019-06-15 17:26:09 +00:00
|
|
|
print(status, end=' ')
|
2013-06-20 14:51:58 +00:00
|
|
|
|
2014-02-17 09:50:25 +00:00
|
|
|
if ci:
|
2024-03-21 13:48:23 +00:00
|
|
|
print(f"{text} done.")
|
2014-02-17 09:50:25 +00:00
|
|
|
else:
|
2019-06-15 17:26:09 +00:00
|
|
|
print()
|
2014-07-21 08:31:51 +00:00
|
|
|
return path
|
2013-06-20 14:51:58 +00:00
|
|
|
|
|
|
|
|
2013-10-26 09:23:16 +00:00
|
|
|
def make_zip(zip_file_path, files, dirs):
|
2013-08-31 01:37:02 +00:00
|
|
|
safe_unlink(zip_file_path)
|
|
|
|
if sys.platform == 'darwin':
|
2020-02-17 00:45:41 +00:00
|
|
|
allfiles = files + dirs
|
|
|
|
execute(['zip', '-r', '-y', zip_file_path] + allfiles)
|
2013-08-31 01:37:02 +00:00
|
|
|
else:
|
2024-03-21 13:48:23 +00:00
|
|
|
with zipfile.ZipFile(zip_file_path, "w",
|
|
|
|
zipfile.ZIP_DEFLATED,
|
|
|
|
allowZip64=True) as zip_file:
|
|
|
|
for filename in files:
|
|
|
|
zip_file.write(filename, filename)
|
|
|
|
for dirname in dirs:
|
|
|
|
for root, _, filenames in os.walk(dirname):
|
|
|
|
for f in filenames:
|
|
|
|
zip_file.write(os.path.join(root, f))
|
|
|
|
zip_file.close()
|
2013-08-31 01:37:02 +00:00
|
|
|
|
2013-06-20 14:51:58 +00:00
|
|
|
|
2013-06-24 09:51:48 +00:00
|
|
|
def rm_rf(path):
|
|
|
|
try:
|
|
|
|
shutil.rmtree(path)
|
2015-07-03 07:07:11 +00:00
|
|
|
except OSError:
|
|
|
|
pass
|
2013-06-24 09:51:48 +00:00
|
|
|
|
|
|
|
|
2013-06-20 14:51:58 +00:00
|
|
|
def safe_unlink(path):
|
|
|
|
try:
|
|
|
|
os.unlink(path)
|
|
|
|
except OSError as e:
|
|
|
|
if e.errno != errno.ENOENT:
|
|
|
|
raise
|
|
|
|
|
|
|
|
|
|
|
|
def safe_mkdir(path):
|
|
|
|
try:
|
|
|
|
os.makedirs(path)
|
|
|
|
except OSError as e:
|
|
|
|
if e.errno != errno.EEXIST:
|
|
|
|
raise
|
2013-08-12 07:01:05 +00:00
|
|
|
|
|
|
|
|
2018-09-16 17:24:07 +00:00
|
|
|
def execute(argv, env=None, cwd=None):
|
|
|
|
if env is None:
|
|
|
|
env = os.environ
|
2014-12-08 17:02:08 +00:00
|
|
|
if is_verbose_mode():
|
2019-06-15 17:26:09 +00:00
|
|
|
print(' '.join(argv))
|
2014-02-26 14:08:01 +00:00
|
|
|
try:
|
2018-09-16 17:24:07 +00:00
|
|
|
output = subprocess.check_output(argv, stderr=subprocess.STDOUT,
|
|
|
|
env=env, cwd=cwd)
|
2014-12-08 17:02:08 +00:00
|
|
|
if is_verbose_mode():
|
2019-06-15 17:26:09 +00:00
|
|
|
print(output)
|
2014-08-12 12:23:59 +00:00
|
|
|
return output
|
2014-02-26 14:08:01 +00:00
|
|
|
except subprocess.CalledProcessError as e:
|
2019-06-15 17:26:09 +00:00
|
|
|
print(e.output)
|
2014-02-26 14:08:01 +00:00
|
|
|
raise e
|
|
|
|
|
|
|
|
|
2018-09-27 18:53:08 +00:00
|
|
|
def get_electron_branding():
|
2015-04-12 04:45:18 +00:00
|
|
|
SOURCE_ROOT = os.path.abspath(os.path.join(__file__, '..', '..', '..'))
|
2019-06-19 21:05:56 +00:00
|
|
|
branding_file_path = os.path.join(
|
|
|
|
SOURCE_ROOT, 'shell', 'app', 'BRANDING.json')
|
2024-03-21 13:48:23 +00:00
|
|
|
with open(branding_file_path, encoding='utf-8') as file_in:
|
|
|
|
return json.load(file_in)
|
2014-12-07 23:42:55 +00:00
|
|
|
|
2022-10-25 06:44:43 +00:00
|
|
|
|
|
|
|
cached_electron_version = None
|
2016-05-24 17:27:46 +00:00
|
|
|
def get_electron_version():
|
2022-10-25 06:44:43 +00:00
|
|
|
global cached_electron_version
|
|
|
|
if cached_electron_version is None:
|
|
|
|
cached_electron_version = str.strip(execute([
|
|
|
|
'node',
|
|
|
|
'-p',
|
|
|
|
'require("./script/lib/get-version").getElectronVersion()'
|
|
|
|
], cwd=ELECTRON_DIR).decode())
|
|
|
|
return cached_electron_version
|
2014-07-21 08:31:51 +00:00
|
|
|
|
2022-04-04 09:32:57 +00:00
|
|
|
def store_artifact(prefix, key_prefix, files):
|
2022-05-06 04:40:34 +00:00
|
|
|
# Azure Storage
|
2022-04-04 09:32:57 +00:00
|
|
|
azput(prefix, key_prefix, files)
|
|
|
|
|
|
|
|
def azput(prefix, key_prefix, files):
|
|
|
|
env = os.environ.copy()
|
|
|
|
output = execute([
|
|
|
|
'node',
|
|
|
|
os.path.join(os.path.dirname(__file__), 'azput.js'),
|
|
|
|
'--prefix', prefix,
|
|
|
|
'--key_prefix', key_prefix,
|
|
|
|
] + files, env)
|
|
|
|
print(output)
|
|
|
|
|
2018-09-27 05:38:06 +00:00
|
|
|
def get_out_dir():
|
2024-06-10 21:58:29 +00:00
|
|
|
out_dir = 'Default'
|
2018-09-27 05:38:06 +00:00
|
|
|
override = os.environ.get('ELECTRON_OUT_DIR')
|
|
|
|
if override is not None:
|
|
|
|
out_dir = override
|
2018-10-08 20:19:40 +00:00
|
|
|
return os.path.join(SRC_DIR, 'out', out_dir)
|
2018-09-27 05:38:06 +00:00
|
|
|
|
2018-09-28 01:24:25 +00:00
|
|
|
# NOTE: This path is not created by gn, it is used as a scratch zone by our
|
|
|
|
# upload scripts
|
2018-09-27 06:48:07 +00:00
|
|
|
def get_dist_dir():
|
|
|
|
return os.path.join(get_out_dir(), 'gen', 'electron_dist')
|
2018-09-27 20:14:13 +00:00
|
|
|
|
|
|
|
def get_electron_exec():
|
2018-10-08 20:19:40 +00:00
|
|
|
out_dir = get_out_dir()
|
|
|
|
|
2018-09-27 20:14:13 +00:00
|
|
|
if sys.platform == 'darwin':
|
2024-03-21 13:48:23 +00:00
|
|
|
return f'{out_dir}/Electron.app/Contents/MacOS/Electron'
|
2022-03-21 02:11:21 +00:00
|
|
|
if sys.platform == 'win32':
|
2024-03-21 13:48:23 +00:00
|
|
|
return f'{out_dir}/electron.exe'
|
2022-03-21 02:11:21 +00:00
|
|
|
if sys.platform == 'linux':
|
2024-03-21 13:48:23 +00:00
|
|
|
return f'{out_dir}/electron'
|
2018-10-08 20:19:40 +00:00
|
|
|
|
|
|
|
raise Exception(
|
2024-03-21 13:48:23 +00:00
|
|
|
f"get_electron_exec: unexpected platform '{sys.platform}'")
|
2019-07-09 08:40:26 +00:00
|
|
|
|
|
|
|
def get_buildtools_executable(name):
|
|
|
|
buildtools = os.path.realpath(os.path.join(ELECTRON_DIR, '..', 'buildtools'))
|
2024-06-17 20:21:50 +00:00
|
|
|
|
|
|
|
if sys.platform == 'darwin':
|
|
|
|
chromium_platform = 'mac_arm64' if platform.machine() == 'arm64' else 'mac'
|
|
|
|
elif sys.platform in ['win32', 'cygwin']:
|
|
|
|
chromium_platform = 'win'
|
|
|
|
elif sys.platform in ['linux', 'linux2']:
|
|
|
|
chromium_platform = 'linux64'
|
|
|
|
else:
|
|
|
|
raise Exception(f"Unsupported platform: {sys.platform}")
|
2024-07-17 09:30:15 +00:00
|
|
|
|
|
|
|
if name == 'clang-format':
|
|
|
|
chromium_platform += '-format'
|
2024-06-17 20:21:50 +00:00
|
|
|
|
2024-06-28 20:39:44 +00:00
|
|
|
path = os.path.join(buildtools, chromium_platform, name)
|
2019-07-09 08:40:26 +00:00
|
|
|
if sys.platform == 'win32':
|
|
|
|
path += '.exe'
|
|
|
|
return path
|
2022-12-13 22:01:20 +00:00
|
|
|
|
2024-06-28 20:39:44 +00:00
|
|
|
def get_depot_tools_executable(name):
|
|
|
|
buildtools = os.path.realpath(
|
|
|
|
os.path.join(ELECTRON_DIR, '..', 'third_party', 'depot_tools'))
|
|
|
|
|
|
|
|
path = os.path.join(buildtools, name)
|
|
|
|
if sys.platform == 'win32':
|
|
|
|
path += '.bat'
|
|
|
|
return path
|
|
|
|
|
2022-12-13 22:01:20 +00:00
|
|
|
def get_linux_binaries():
|
|
|
|
return [
|
|
|
|
'chrome-sandbox',
|
|
|
|
'chrome_crashpad_handler',
|
|
|
|
get_electron_branding()['project_name'],
|
|
|
|
'libEGL.so',
|
|
|
|
'libGLESv2.so',
|
|
|
|
'libffmpeg.so',
|
|
|
|
'libvk_swiftshader.so',
|
|
|
|
]
|