aboutsummaryrefslogtreecommitdiffstats
path: root/setup.py
diff options
context:
space:
mode:
authorpukkandan <pukkandan.ytdlp@gmail.com>2022-07-08 02:23:24 +0530
committerpukkandan <pukkandan.ytdlp@gmail.com>2022-07-09 01:52:07 +0530
commit7b84d6f9b32aa432189db5b481c33bcca2b47da0 (patch)
treee502c88d498d0fbf8314b0d598447163219a7b80 /setup.py
parent12a1b2254db81caa3c68d4dccb848ca73410e66e (diff)
downloadhypervideo-pre-7b84d6f9b32aa432189db5b481c33bcca2b47da0.tar.lz
hypervideo-pre-7b84d6f9b32aa432189db5b481c33bcca2b47da0.tar.xz
hypervideo-pre-7b84d6f9b32aa432189db5b481c33bcca2b47da0.zip
[build] Improve `setup.py`
Closes #4296
Diffstat (limited to 'setup.py')
-rw-r--r--setup.py48
1 files changed, 28 insertions, 20 deletions
diff --git a/setup.py b/setup.py
index 9803e928c..ef9d3e91b 100644
--- a/setup.py
+++ b/setup.py
@@ -1,6 +1,7 @@
#!/usr/bin/env python3
import os.path
+import subprocess
import sys
import warnings
@@ -10,7 +11,6 @@ try:
except ImportError:
from distutils.core import Command, setup
setuptools_available = False
-from distutils.spawn import spawn
def read(fname):
@@ -36,12 +36,24 @@ LONG_DESCRIPTION = '\n\n'.join((
REQUIREMENTS = read('requirements.txt').splitlines()
-if sys.argv[1:2] == ['py2exe']:
+def packages():
+ if setuptools_available:
+ return find_packages(exclude=('youtube_dl', 'youtube_dlc', 'test', 'ytdlp_plugins'))
+
+ return [
+ 'yt_dlp', 'yt_dlp.extractor', 'yt_dlp.downloader', 'yt_dlp.postprocessor', 'yt_dlp.compat',
+ 'yt_dlp.extractor.anvato_token_generator',
+ ]
+
+
+def py2exe_params():
import py2exe # noqa: F401
+
warnings.warn(
'py2exe builds do not support pycryptodomex and needs VC++14 to run. '
'The recommended way is to use "pyinst.py" to build using pyinstaller')
- params = {
+
+ return {
'console': [{
'script': './yt_dlp/__main__.py',
'dest_base': 'yt-dlp',
@@ -50,6 +62,7 @@ if sys.argv[1:2] == ['py2exe']:
'comments': LONG_DESCRIPTION.split('\n')[0],
'product_name': 'yt-dlp',
'product_version': VERSION,
+ 'icon_resources': [(1, 'devscripts/logo.ico')],
}],
'options': {
'py2exe': {
@@ -66,7 +79,8 @@ if sys.argv[1:2] == ['py2exe']:
'zipfile': None
}
-else:
+
+def build_params():
files_spec = [
('share/bash-completion/completions', ['completions/bash/yt-dlp']),
('share/zsh/site-functions', ['completions/zsh/_yt-dlp']),
@@ -74,25 +88,23 @@ else:
('share/doc/yt_dlp', ['README.txt']),
('share/man/man1', ['yt-dlp.1'])
]
- root = os.path.dirname(os.path.abspath(__file__))
data_files = []
for dirname, files in files_spec:
resfiles = []
for fn in files:
if not os.path.exists(fn):
- warnings.warn('Skipping file %s since it is not present. Try running `make pypi-files` first' % fn)
+ warnings.warn(f'Skipping file {fn} since it is not present. Try running " make pypi-files " first')
else:
resfiles.append(fn)
data_files.append((dirname, resfiles))
- params = {
- 'data_files': data_files,
- }
+ params = {'data_files': data_files}
if setuptools_available:
params['entry_points'] = {'console_scripts': ['yt-dlp = yt_dlp:main']}
else:
params['scripts'] = ['yt-dlp']
+ return params
class build_lazy_extractors(Command):
@@ -106,16 +118,13 @@ class build_lazy_extractors(Command):
pass
def run(self):
- spawn([sys.executable, 'devscripts/make_lazy_extractors.py', 'yt_dlp/extractor/lazy_extractors.py'],
- dry_run=self.dry_run)
-
-
-if setuptools_available:
- packages = find_packages(exclude=('youtube_dl', 'youtube_dlc', 'test', 'ytdlp_plugins'))
-else:
- packages = ['yt_dlp', 'yt_dlp.downloader', 'yt_dlp.extractor', 'yt_dlp.postprocessor']
+ if self.dry_run:
+ print('Skipping build of lazy extractors in dry run mode')
+ return
+ subprocess.run([sys.executable, 'devscripts/make_lazy_extractors.py', 'yt_dlp/extractor/lazy_extractors.py'])
+params = py2exe_params() if sys.argv[1:2] == ['py2exe'] else build_params()
setup(
name='yt-dlp',
version=VERSION,
@@ -125,8 +134,9 @@ setup(
long_description=LONG_DESCRIPTION,
long_description_content_type='text/markdown',
url='https://github.com/yt-dlp/yt-dlp',
- packages=packages,
+ packages=packages(),
install_requires=REQUIREMENTS,
+ python_requires='>=3.6',
project_urls={
'Documentation': 'https://github.com/yt-dlp/yt-dlp#readme',
'Source': 'https://github.com/yt-dlp/yt-dlp',
@@ -150,8 +160,6 @@ setup(
'License :: Public Domain',
'Operating System :: OS Independent',
],
- python_requires='>=3.6',
-
cmdclass={'build_lazy_extractors': build_lazy_extractors},
**params
)