X-Git-Url: https://jfr.im/git/yt-dlp.git/blobdiff_plain/da7f321e9338624375eab758d822445d2846e771..cc52de43568d8cd58c7e2ef4e5cecf609da28a9c:/setup.py diff --git a/setup.py b/setup.py index babdc45af..8f74c06c1 100644 --- a/setup.py +++ b/setup.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 # coding: utf-8 from setuptools import setup, Command, find_packages @@ -9,45 +9,44 @@ # 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')) +exec(compile(open('yt_dlp/version.py').read(), 'yt_dlp/version.py', 'exec')) DESCRIPTION = 'Command-line program to download videos from YouTube.com and many other other video platforms.' LONG_DESCRIPTION = '\n\n'.join(( 'Official repository: ', - '**PS**: Many links in this document will not work since this is a copy of the README.md from Github', - open("README.md", "r", encoding="utf-8").read())) + '**PS**: Some links in this document will not work since this is a copy of the README.md from Github', + open('README.md', 'r', encoding='utf-8').read())) REQUIREMENTS = ['mutagen', 'pycryptodome'] - -if len(sys.argv) >= 2 and sys.argv[1] == 'py2exe': - print("inv") -else: - files_spec = [ - ('share/bash-completion/completions', ['completions/bash/yt-dlp']), - ('share/zsh/site-functions', ['completions/zsh/_yt-dlp']), - ('share/fish/vendor_completions.d', ['completions/fish/yt-dlp.fish']), - ('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) - else: - resfiles.append(fn) - data_files.append((dirname, resfiles)) - - params = { - 'data_files': data_files, - } - params['entry_points'] = {'console_scripts': ['yt-dlp = yt_dlp:main']} +if sys.argv[1:2] == ['py2exe']: + raise NotImplementedError('py2exe is not currently supported; instead, use "pyinst.py" to build with pyinstaller') + + +files_spec = [ + ('share/bash-completion/completions', ['completions/bash/yt-dlp']), + ('share/zsh/site-functions', ['completions/zsh/_yt-dlp']), + ('share/fish/vendor_completions.d', ['completions/fish/yt-dlp.fish']), + ('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) + else: + resfiles.append(fn) + data_files.append((dirname, resfiles)) + +params = { + 'data_files': data_files, +} +params['entry_points'] = {'console_scripts': ['yt-dlp = yt_dlp:main']} class build_lazy_extractors(Command): @@ -61,23 +60,21 @@ def finalize_options(self): pass def run(self): - spawn( - [sys.executable, 'devscripts/make_lazy_extractors.py', 'yt_dlp/extractor/lazy_extractors.py'], - dry_run=self.dry_run, - ) + spawn([sys.executable, 'devscripts/make_lazy_extractors.py', 'yt_dlp/extractor/lazy_extractors.py'], + dry_run=self.dry_run) -packages = find_packages(exclude=("youtube_dl", "test", "ytdlp_plugins")) +packages = find_packages(exclude=('youtube_dl', 'test', 'ytdlp_plugins')) setup( - name="yt-dlp", + name='yt-dlp', version=__version__, - maintainer="pukkandan", - maintainer_email="pukkandan.ytdlp@gmail.com", + maintainer='pukkandan', + maintainer_email='pukkandan.ytdlp@gmail.com', description=DESCRIPTION, long_description=LONG_DESCRIPTION, - long_description_content_type="text/markdown", - url="https://github.com/yt-dlp/yt-dlp", + long_description_content_type='text/markdown', + url='https://github.com/yt-dlp/yt-dlp', packages=packages, install_requires=REQUIREMENTS, project_urls={ @@ -87,30 +84,20 @@ def run(self): #'Funding': 'https://donate.pypi.org', }, classifiers=[ - "Topic :: Multimedia :: Video", - "Development Status :: 5 - Production/Stable", - "Environment :: Console", - "Programming Language :: Python", - "Programming Language :: Python :: 2", - "Programming Language :: Python :: 2.6", - "Programming Language :: Python :: 2.7", - "Programming Language :: Python :: 3", - "Programming Language :: Python :: 3.2", - "Programming Language :: Python :: 3.3", - "Programming Language :: Python :: 3.4", - "Programming Language :: Python :: 3.5", - "Programming Language :: Python :: 3.6", - "Programming Language :: Python :: 3.7", - "Programming Language :: Python :: 3.8", - "Programming Language :: Python :: Implementation", - "Programming Language :: Python :: Implementation :: CPython", - "Programming Language :: Python :: Implementation :: IronPython", - "Programming Language :: Python :: Implementation :: Jython", - "Programming Language :: Python :: Implementation :: PyPy", - "License :: Public Domain", - "Operating System :: OS Independent", + 'Topic :: Multimedia :: Video', + 'Development Status :: 5 - Production/Stable', + 'Environment :: Console', + 'Programming Language :: Python', + 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: Implementation', + 'Programming Language :: Python :: Implementation :: CPython', + 'Programming Language :: Python :: Implementation :: PyPy', + 'License :: Public Domain', + 'Operating System :: OS Independent', ], - python_requires='>=2.6', + python_requires='>=3.6', cmdclass={'build_lazy_extractors': build_lazy_extractors}, **params