|
|
@ -3,7 +3,7 @@ import os
|
|
|
|
import platform
|
|
|
|
import platform
|
|
|
|
import sys
|
|
|
|
import sys
|
|
|
|
|
|
|
|
|
|
|
|
from PyInstaller.utils.hooks import collect_submodules
|
|
|
|
from PyInstaller.__main__ import run as run_pyinstaller
|
|
|
|
|
|
|
|
|
|
|
|
OS_NAME = platform.system()
|
|
|
|
OS_NAME = platform.system()
|
|
|
|
if OS_NAME == 'Windows':
|
|
|
|
if OS_NAME == 'Windows':
|
|
|
@ -20,18 +20,22 @@ if OS_NAME == 'Windows':
|
|
|
|
elif OS_NAME == 'Darwin':
|
|
|
|
elif OS_NAME == 'Darwin':
|
|
|
|
pass
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
raise Exception('{OS_NAME} is not supported')
|
|
|
|
raise Exception(f'{OS_NAME} is not supported')
|
|
|
|
|
|
|
|
|
|
|
|
ARCH = platform.architecture()[0][:2]
|
|
|
|
ARCH = platform.architecture()[0][:2]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
def main():
|
|
|
|
opts = parse_options()
|
|
|
|
opts = parse_options()
|
|
|
|
version = read_version()
|
|
|
|
version = read_version('yt_dlp/version.py')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onedir = '--onedir' in opts or '-D' in opts
|
|
|
|
|
|
|
|
if not onedir and '-F' not in opts and '--onefile' not in opts:
|
|
|
|
|
|
|
|
opts.append('--onefile')
|
|
|
|
|
|
|
|
|
|
|
|
suffix = '_macos' if OS_NAME == 'Darwin' else '_x86' if ARCH == '32' else ''
|
|
|
|
suffix = '_macos' if OS_NAME == 'Darwin' else '_x86' if ARCH == '32' else ''
|
|
|
|
final_file = 'dist/%syt-dlp%s%s' % (
|
|
|
|
final_file = 'dist/%syt-dlp%s%s' % (
|
|
|
|
'yt-dlp/' if '--onedir' in opts else '', suffix, '.exe' if OS_NAME == 'Windows' else '')
|
|
|
|
'yt-dlp/' if onedir else '', suffix, '.exe' if OS_NAME == 'Windows' else '')
|
|
|
|
|
|
|
|
|
|
|
|
print(f'Building yt-dlp v{version} {ARCH}bit for {OS_NAME} with options {opts}')
|
|
|
|
print(f'Building yt-dlp v{version} {ARCH}bit for {OS_NAME} with options {opts}')
|
|
|
|
print('Remember to update the version using "devscripts/update-version.py"')
|
|
|
|
print('Remember to update the version using "devscripts/update-version.py"')
|
|
|
@ -45,17 +49,16 @@ def main():
|
|
|
|
'--icon=devscripts/logo.ico',
|
|
|
|
'--icon=devscripts/logo.ico',
|
|
|
|
'--upx-exclude=vcruntime140.dll',
|
|
|
|
'--upx-exclude=vcruntime140.dll',
|
|
|
|
'--noconfirm',
|
|
|
|
'--noconfirm',
|
|
|
|
|
|
|
|
# NB: Modules that are only imported dynamically must be added here.
|
|
|
|
|
|
|
|
# --collect-submodules may not work correctly if user has a yt-dlp installed via PIP
|
|
|
|
|
|
|
|
'--hidden-import=yt_dlp.compat._legacy',
|
|
|
|
*dependency_options(),
|
|
|
|
*dependency_options(),
|
|
|
|
*opts,
|
|
|
|
*opts,
|
|
|
|
'--collect-submodules=yt_dlp',
|
|
|
|
|
|
|
|
'yt_dlp/__main__.py',
|
|
|
|
'yt_dlp/__main__.py',
|
|
|
|
]
|
|
|
|
]
|
|
|
|
print(f'Running PyInstaller with {opts}')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import PyInstaller.__main__
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PyInstaller.__main__.run(opts)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
print(f'Running PyInstaller with {opts}')
|
|
|
|
|
|
|
|
run_pyinstaller(opts)
|
|
|
|
set_version_info(final_file, version)
|
|
|
|
set_version_info(final_file, version)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -66,11 +69,13 @@ def parse_options():
|
|
|
|
if ARCH != opts[0]:
|
|
|
|
if ARCH != opts[0]:
|
|
|
|
raise Exception(f'{opts[0]}bit executable cannot be built on a {ARCH}bit system')
|
|
|
|
raise Exception(f'{opts[0]}bit executable cannot be built on a {ARCH}bit system')
|
|
|
|
opts = opts[1:]
|
|
|
|
opts = opts[1:]
|
|
|
|
return opts or ['--onefile']
|
|
|
|
return opts
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def read_version():
|
|
|
|
# Get the version from yt_dlp/version.py without importing the package
|
|
|
|
exec(compile(open('yt_dlp/version.py').read(), 'yt_dlp/version.py', 'exec'))
|
|
|
|
def read_version(fname):
|
|
|
|
|
|
|
|
with open(fname, encoding='utf-8') as f:
|
|
|
|
|
|
|
|
exec(compile(f.read(), fname, 'exec'))
|
|
|
|
return locals()['__version__']
|
|
|
|
return locals()['__version__']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -80,10 +85,12 @@ def version_to_list(version):
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def dependency_options():
|
|
|
|
def dependency_options():
|
|
|
|
dependencies = [pycryptodome_module(), 'mutagen', 'brotli', 'certifi'] + collect_submodules('websockets')
|
|
|
|
# Due to the current implementation, these are auto-detected, but explicitly add them just in case
|
|
|
|
excluded_modules = ['test', 'ytdlp_plugins', 'youtube-dl', 'youtube-dlc']
|
|
|
|
dependencies = [pycryptodome_module(), 'mutagen', 'brotli', 'certifi', 'websockets']
|
|
|
|
|
|
|
|
excluded_modules = ['test', 'ytdlp_plugins', 'youtube_dl', 'youtube_dlc']
|
|
|
|
|
|
|
|
|
|
|
|
yield from (f'--hidden-import={module}' for module in dependencies)
|
|
|
|
yield from (f'--hidden-import={module}' for module in dependencies)
|
|
|
|
|
|
|
|
yield '--collect-submodules=websockets'
|
|
|
|
yield from (f'--exclude-module={module}' for module in excluded_modules)
|
|
|
|
yield from (f'--exclude-module={module}' for module in excluded_modules)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|