-#!/usr/bin/env python
+#!/usr/bin/env python3
# coding: utf-8
from __future__ import unicode_literals
import sys
-# import os
import platform
+from PyInstaller.utils.hooks import collect_submodules
from PyInstaller.utils.win32.versioninfo import (
VarStruct, VarFileInfo, StringStruct, StringTable,
StringFileInfo, FixedFileInfo, VSVersionInfo, SetVersion,
)
import PyInstaller.__main__
-arch = sys.argv[1] if len(sys.argv) > 1 else platform.architecture()[0][:2]
+arch = platform.architecture()[0][:2]
assert arch in ('32', '64')
-print('Building %sbit version' % arch)
_x86 = '_x86' if arch == '32' else ''
-FILE_DESCRIPTION = 'Media Downloader%s' % (' (32 Bit)' if _x86 else '')
+# Compatability with older arguments
+opts = sys.argv[1:]
+if opts[0:1] in (['32'], ['64']):
+ if arch != opts[0]:
+ raise Exception(f'{opts[0]}bit executable cannot be built on a {arch}bit system')
+ opts = opts[1:]
+opts = opts or ['--onefile']
-# root_dir = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
-# print('Changing working directory to %s' % root_dir)
-# os.chdir(root_dir)
+print(f'Building {arch}bit version with options {opts}')
-exec(compile(open('youtube_dlc/version.py').read(), 'youtube_dlc/version.py', 'exec'))
+FILE_DESCRIPTION = 'yt-dlp%s' % (' (32 Bit)' if _x86 else '')
+
+exec(compile(open('yt_dlp/version.py').read(), 'yt_dlp/version.py', 'exec'))
VERSION = locals()['__version__']
VERSION_LIST = VERSION.split('.')
StringFileInfo([
StringTable(
'040904B0', [
- StringStruct('Comments', 'Youtube-dlc%s Command Line Interface.' % _x86),
- StringStruct('CompanyName', 'https://github.com/pukkandan/yt-dlp'),
+ StringStruct('Comments', 'yt-dlp%s Command Line Interface.' % _x86),
+ StringStruct('CompanyName', 'https://github.com/yt-dlp'),
StringStruct('FileDescription', FILE_DESCRIPTION),
StringStruct('FileVersion', VERSION),
- StringStruct('InternalName', 'youtube-dlc%s' % _x86),
+ StringStruct('InternalName', 'yt-dlp%s' % _x86),
StringStruct(
'LegalCopyright',
- 'pukkandan@gmail.com | UNLICENSE',
+ 'pukkandan.ytdlp@gmail.com | UNLICENSE',
),
- StringStruct('OriginalFilename', 'youtube-dlc%s.exe' % _x86),
- StringStruct('ProductName', 'Youtube-dlc%s' % _x86),
- StringStruct('ProductVersion', '%s%s' % (VERSION, _x86)),
+ StringStruct('OriginalFilename', 'yt-dlp%s.exe' % _x86),
+ StringStruct('ProductName', 'yt-dlp%s' % _x86),
+ StringStruct(
+ 'ProductVersion',
+ '%s%s on Python %s' % (VERSION, _x86, platform.python_version())),
])]),
VarFileInfo([VarStruct('Translation', [0, 1200])])
]
)
+
+def pycryptodome_module():
+ try:
+ import Cryptodome # noqa: F401
+ except ImportError:
+ try:
+ import Crypto # noqa: F401
+ print('WARNING: Using Crypto since Cryptodome is not available. '
+ 'Install with: pip install pycryptodomex', file=sys.stderr)
+ return 'Crypto'
+ except ImportError:
+ pass
+ return 'Cryptodome'
+
+
+dependancies = [pycryptodome_module(), 'mutagen'] + collect_submodules('websockets')
+excluded_modules = ['test', 'ytdlp_plugins', 'youtube-dl', 'youtube-dlc']
+
PyInstaller.__main__.run([
- '--name=youtube-dlc%s' % _x86,
- '--onefile',
- '--icon=devscripts/cloud.ico',
- '--exclude-module=youtube_dl',
- '--exclude-module=test',
- '--exclude-module=ytdlp_plugins',
- '--hidden-import=mutagen',
- '--hidden-import=Crypto',
- 'youtube_dlc/__main__.py',
+ '--name=yt-dlp%s' % _x86,
+ '--icon=devscripts/logo.ico',
+ *[f'--exclude-module={module}' for module in excluded_modules],
+ *[f'--hidden-import={module}' for module in dependancies],
+ '--upx-exclude=vcruntime140.dll',
+ '--noconfirm',
+ *opts,
+ 'yt_dlp/__main__.py',
])
-SetVersion('dist/youtube-dlc%s.exe' % _x86, VERSION_FILE)
+SetVersion('dist/%syt-dlp%s.exe' % ('yt-dlp/' if '--onedir' in opts else '', _x86), VERSION_FILE)