aboutsummaryrefslogtreecommitdiffstats
path: root/setup.py
diff options
context:
space:
mode:
Diffstat (limited to 'setup.py')
-rw-r--r--setup.py147
1 files changed, 68 insertions, 79 deletions
diff --git a/setup.py b/setup.py
index cb9de29..c56148e 100644
--- a/setup.py
+++ b/setup.py
@@ -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