diff options
Diffstat (limited to 'setup.py')
-rw-r--r-- | setup.py | 147 |
1 files changed, 68 insertions, 79 deletions
@@ -1,66 +1,64 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 # coding: utf-8 - -from __future__ import print_function - import os.path import warnings import sys try: - from setuptools import setup, Command + from setuptools import setup, Command, find_packages setuptools_available = True except ImportError: from distutils.core import setup, Command setuptools_available = False from distutils.spawn import spawn -try: - # This will create an exe that needs Microsoft Visual C++ 2008 - # Redistributable Package +# Get the version from hypervideo_dl/version.py without importing the package +exec(compile(open('hypervideo_dl/version.py').read(), 'hypervideo_dl/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: <https://github.com/hypervideo/hypervideo>', + '**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', 'pycryptodomex', 'websockets'] + + +if sys.argv[1:2] == ['py2exe']: import py2exe -except ImportError: - if len(sys.argv) >= 2 and sys.argv[1] == 'py2exe': - print('Cannot import py2exe', file=sys.stderr) - exit(1) - -py2exe_options = { - 'bundle_files': 1, - 'compressed': 1, - 'optimize': 2, - 'dist_dir': '.', - 'dll_excludes': ['w9xpopen.exe', 'crypt32.dll'], -} + warnings.warn( + 'Building with py2exe is not officially supported. ' + 'The recommended way is to use "pyinst.py" to build using pyinstaller') + params = { + 'console': [{ + 'script': './hypervideo_dl/__main__.py', + 'dest_base': 'hypervideo', + 'version': __version__, + 'description': DESCRIPTION, + 'comments': LONG_DESCRIPTION.split('\n')[0], + 'product_name': 'hypervideo', + 'product_version': __version__, + }], + 'options': { + 'py2exe': { + 'bundle_files': 0, + 'compressed': 1, + 'optimize': 2, + 'dist_dir': './dist', + 'excludes': ['Crypto', 'Cryptodome'], # py2exe cannot import Crypto + 'dll_excludes': ['w9xpopen.exe', 'crypt32.dll'], + } + }, + 'zipfile': None + } -# Get the version from hypervideo_dl/version.py without importing the package -exec(compile(open('hypervideo_dl/version.py').read(), - 'hypervideo_dl/version.py', 'exec')) - -DESCRIPTION = 'YouTube video downloader' -LONG_DESCRIPTION = 'Command-line program to download videos from YouTube.com and other video sites' - -py2exe_console = [{ - 'script': './hypervideo_dl/__main__.py', - 'dest_base': 'hypervideo', - 'version': __version__, - 'description': DESCRIPTION, - 'comments': LONG_DESCRIPTION, - 'product_name': 'hypervideo', - 'product_version': __version__, -}] - -py2exe_params = { - 'console': py2exe_console, - 'options': {'py2exe': py2exe_options}, - 'zipfile': None -} - -if len(sys.argv) >= 2 and sys.argv[1] == 'py2exe': - params = py2exe_params else: files_spec = [ - ('etc/bash_completion.d', ['hypervideo.bash-completion']), - ('etc/fish/completions', ['hypervideo.fish']), + ('share/bash-completion/completions', ['completions/bash/hypervideo']), + ('share/zsh/site-functions', ['completions/zsh/_hypervideo']), + ('share/fish/vendor_completions.d', ['completions/fish/hypervideo.fish']), ('share/doc/hypervideo_dl', ['README.txt']), ('share/man/man1', ['hypervideo.1']) ] @@ -70,7 +68,7 @@ else: 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) + 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)) @@ -78,10 +76,12 @@ else: params = { 'data_files': data_files, } + if setuptools_available: params['entry_points'] = {'console_scripts': ['hypervideo = hypervideo_dl:main']} else: - params['scripts'] = ['bin/hypervideo'] + params['scripts'] = ['hypervideo'] + class build_lazy_extractors(Command): description = 'Build the extractor lazy loading module' @@ -94,54 +94,43 @@ class build_lazy_extractors(Command): pass def run(self): - spawn( - [sys.executable, 'devscripts/make_lazy_extractors.py', 'hypervideo_dl/extractor/lazy_extractors.py'], - dry_run=self.dry_run, - ) + spawn([sys.executable, 'devscripts/make_lazy_extractors.py', 'hypervideo_dl/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 = ['hypervideo_dl', 'hypervideo_dl.downloader', 'hypervideo_dl.extractor', 'hypervideo_dl.postprocessor'] + setup( - name='hypervideo_dl', + name='hypervideo', version=__version__, - description=DESCRIPTION, - long_description=LONG_DESCRIPTION, - url='https://git.conocimientoslibres.ga/software/hypervideo.git', - author='Ricardo Garcia', - author_email='ytdl@yt-dl.org', maintainer='Jesús E..', maintainer_email='heckyel@hyperbola.info', license='CC0-1.0', - packages=[ - 'hypervideo_dl', - 'hypervideo_dl.extractor', 'hypervideo_dl.downloader', - 'hypervideo_dl.postprocessor'], - - # Provokes warning on most systems (why?!) - # test_suite = 'nose.collector', - # test_requires = ['nosetest'], - + description=DESCRIPTION, + long_description=LONG_DESCRIPTION, + long_description_content_type='text/markdown', + url='https://git.conocimientoslibres.ga/software/hypervideo.git', + packages=packages, + install_requires=REQUIREMENTS, classifiers=[ 'Topic :: Multimedia :: Video', 'Development Status :: 5 - Production/Stable', 'Environment :: Console', - 'License :: Public Domain', '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', ], + python_requires='>=3.6', cmdclass={'build_lazy_extractors': build_lazy_extractors}, **params |