X-Git-Url: https://jfr.im/git/yt-dlp.git/blobdiff_plain/c76eb41bb9e7e0a106ce44f4afcf74b0c00a3fb2..cc52de43568d8cd58c7e2ef4e5cecf609da28a9c:/setup.py diff --git a/setup.py b/setup.py index 346c5cb64..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 @@ -7,40 +7,47 @@ import sys from distutils.spawn import spawn -# Get the version from youtube_dlc/version.py without importing the package -exec(compile(open('youtube_dlc/version.py').read(), - 'youtube_dlc/version.py', 'exec')) - -DESCRIPTION = 'Media downloader supporting various sites such as youtube' -LONG_DESCRIPTION = 'Command-line program to download videos from YouTube.com and other video sites. Based on a more active community fork.' - -if len(sys.argv) >= 2 and sys.argv[1] == 'py2exe': - print("inv") -else: - files_spec = [ - ('etc/bash_completion.d', ['youtube-dlc.bash-completion']), - ('etc/fish/completions', ['youtube-dlc.fish']), - ('share/doc/youtube_dlc', ['README.txt']), - ('share/man/man1', ['youtube-dlc.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. Type make to build all automatically generated files.' % fn) - else: - resfiles.append(fn) - data_files.append((dirname, resfiles)) - - params = { - 'data_files': data_files, - } - #if setuptools_available: - params['entry_points'] = {'console_scripts': ['youtube-dlc = youtube_dlc:main']} - #else: - # params['scripts'] = ['bin/youtube-dlc'] + +# 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')) + + +DESCRIPTION = 'Command-line program to download videos from YouTube.com and many other other video platforms.' + +LONG_DESCRIPTION = '\n\n'.join(( + 'Official repository: ', + '**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 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): description = 'Build the extractor lazy loading module' @@ -53,51 +60,45 @@ def finalize_options(self): pass def run(self): - spawn( - [sys.executable, 'devscripts/make_lazy_extractors.py', 'youtube_dlc/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')) setup( - name="youtube_dlc", + name='yt-dlp', version=__version__, - maintainer="Tom-Oliver Heidel", - maintainer_email="theidel@uni-bremen.de", + maintainer='pukkandan', + maintainer_email='pukkandan.ytdlp@gmail.com', description=DESCRIPTION, long_description=LONG_DESCRIPTION, - # long_description_content_type="text/markdown", - url="https://github.com/pukkandan/yt-dlc", - packages=find_packages(exclude=("youtube_dl","test",)), - #packages=[ - # 'youtube_dlc', - # 'youtube_dlc.extractor', 'youtube_dlc.downloader', - # 'youtube_dlc.postprocessor'], + long_description_content_type='text/markdown', + url='https://github.com/yt-dlp/yt-dlp', + packages=packages, + install_requires=REQUIREMENTS, + project_urls={ + 'Documentation': 'https://yt-dlp.readthedocs.io', + 'Source': 'https://github.com/yt-dlp/yt-dlp', + 'Tracker': 'https://github.com/yt-dlp/yt-dlp/issues', + #'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', - - cmdclass={'build_lazy_extractors': build_lazy_extractors}, + python_requires='>=3.6', + + cmdclass={'build_lazy_extractors': build_lazy_extractors}, **params )