224 строки
5.9 KiB
Python
224 строки
5.9 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from setuptools import setup, find_packages
|
|
|
|
import os
|
|
import re
|
|
import sys
|
|
import codecs
|
|
|
|
try:
|
|
import platform
|
|
_pyimp = platform.python_implementation
|
|
except (AttributeError, ImportError):
|
|
def _pyimp():
|
|
return 'Python'
|
|
|
|
E_UNSUPPORTED_PYTHON = """
|
|
----------------------------------------
|
|
Celery 4.0 requires %s %s or later!
|
|
----------------------------------------
|
|
|
|
- For CPython 2.6, PyPy 1.x, Jython 2.6, CPython 3.2->3.3; use Celery 3.1:
|
|
|
|
$ pip install 'celery<4'
|
|
|
|
- For CPython 2.5, Jython 2.5; use Celery 3.0:
|
|
|
|
$ pip install 'celery<3.1'
|
|
|
|
- For CPython 2.4; use Celery 2.2:
|
|
|
|
$ pip install 'celery<2.3'
|
|
"""
|
|
|
|
PYIMP = _pyimp()
|
|
PY26_OR_LESS = sys.version_info < (2, 7)
|
|
PY3 = sys.version_info[0] == 3
|
|
PY33_OR_LESS = PY3 and sys.version_info < (3, 4)
|
|
JYTHON = sys.platform.startswith('java')
|
|
PYPY_VERSION = getattr(sys, 'pypy_version_info', None)
|
|
PYPY = PYPY_VERSION is not None
|
|
PYPY24_ATLEAST = PYPY_VERSION and PYPY_VERSION >= (2, 4)
|
|
|
|
if PY26_OR_LESS:
|
|
raise Exception(E_UNSUPPORTED_PYTHON % (PYIMP, '2.7'))
|
|
elif PY33_OR_LESS and not PYPY24_ATLEAST:
|
|
raise Exception(E_UNSUPPORTED_PYTHON % (PYIMP, '3.4'))
|
|
|
|
# -*- Upgrading from older versions -*-
|
|
|
|
downgrade_packages = [
|
|
'celery.app.task',
|
|
]
|
|
orig_path = sys.path[:]
|
|
for path in (os.path.curdir, os.getcwd()):
|
|
if path in sys.path:
|
|
sys.path.remove(path)
|
|
try:
|
|
import imp
|
|
import shutil
|
|
for pkg in downgrade_packages:
|
|
try:
|
|
parent, module = pkg.rsplit('.', 1)
|
|
print('- Trying to upgrade %r in %r' % (module, parent))
|
|
parent_mod = __import__(parent, None, None, [parent])
|
|
_, mod_path, _ = imp.find_module(module, parent_mod.__path__)
|
|
if mod_path.endswith('/' + module):
|
|
print('- force upgrading previous installation')
|
|
print(' - removing {0!r} package...'.format(mod_path))
|
|
try:
|
|
shutil.rmtree(os.path.abspath(mod_path))
|
|
except Exception:
|
|
sys.stderr.write('Could not remove {0!r}: {1!r}\n'.format(
|
|
mod_path, sys.exc_info[1]))
|
|
except ImportError:
|
|
print('- upgrade %s: no old version found.' % module)
|
|
except:
|
|
pass
|
|
finally:
|
|
sys.path[:] = orig_path
|
|
|
|
NAME = 'celery'
|
|
entrypoints = {}
|
|
extra = {}
|
|
|
|
# -*- Classifiers -*-
|
|
|
|
classes = """
|
|
Development Status :: 5 - Production/Stable
|
|
License :: OSI Approved :: BSD License
|
|
Topic :: System :: Distributed Computing
|
|
Topic :: Software Development :: Object Brokering
|
|
Programming Language :: Python
|
|
Programming Language :: Python :: 2
|
|
Programming Language :: Python :: 2.7
|
|
Programming Language :: Python :: 3
|
|
Programming Language :: Python :: 3.4
|
|
Programming Language :: Python :: 3.5
|
|
Programming Language :: Python :: Implementation :: CPython
|
|
Programming Language :: Python :: Implementation :: PyPy
|
|
Programming Language :: Python :: Implementation :: Jython
|
|
Operating System :: OS Independent
|
|
"""
|
|
classifiers = [s.strip() for s in classes.split('\n') if s]
|
|
|
|
# -*- Distribution Meta -*-
|
|
|
|
re_meta = re.compile(r'__(\w+?)__\s*=\s*(.*)')
|
|
re_vers = re.compile(r'VERSION\s*=.*?\((.*?)\)')
|
|
re_doc = re.compile(r'^"""(.+?)"""')
|
|
|
|
|
|
def rq(s):
|
|
return s.strip("\"'")
|
|
|
|
|
|
def add_default(m):
|
|
attr_name, attr_value = m.groups()
|
|
return ((attr_name, rq(attr_value)),)
|
|
|
|
|
|
def add_version(m):
|
|
v = list(map(rq, m.groups()[0].split(', ')))
|
|
return (('VERSION', '.'.join(v[0:3]) + ''.join(v[3:])),)
|
|
|
|
|
|
def add_doc(m):
|
|
return (('doc', m.groups()[0]),)
|
|
|
|
pats = {re_meta: add_default,
|
|
re_vers: add_version,
|
|
re_doc: add_doc}
|
|
here = os.path.abspath(os.path.dirname(__file__))
|
|
with open(os.path.join(here, 'celery/__init__.py')) as meta_fh:
|
|
meta = {}
|
|
for line in meta_fh:
|
|
if line.strip() == '# -eof meta-':
|
|
break
|
|
for pattern, handler in pats.items():
|
|
m = pattern.match(line.strip())
|
|
if m:
|
|
meta.update(handler(m))
|
|
|
|
# -*- Installation Requires -*-
|
|
|
|
|
|
def strip_comments(l):
|
|
return l.split('#', 1)[0].strip()
|
|
|
|
|
|
def _pip_requirement(req):
|
|
if req.startswith('-r '):
|
|
_, path = req.split()
|
|
return reqs(*path.split('/'))
|
|
return [req]
|
|
|
|
|
|
def _reqs(*f):
|
|
return [
|
|
_pip_requirement(r) for r in (
|
|
strip_comments(l) for l in open(
|
|
os.path.join(os.getcwd(), 'requirements', *f)).readlines()
|
|
) if r]
|
|
|
|
|
|
def reqs(*f):
|
|
return [req for subreq in _reqs(*f) for req in subreq]
|
|
|
|
install_requires = reqs('default.txt')
|
|
if JYTHON:
|
|
install_requires.extend(reqs('jython.txt'))
|
|
|
|
# -*- Long Description -*-
|
|
|
|
if os.path.exists('README.rst'):
|
|
long_description = codecs.open('README.rst', 'r', 'utf-8').read()
|
|
else:
|
|
long_description = 'See http://pypi.python.org/pypi/celery'
|
|
|
|
# -*- Entry Points -*- #
|
|
|
|
console_scripts = entrypoints['console_scripts'] = [
|
|
'celery = celery.__main__:main',
|
|
]
|
|
|
|
# -*- Extras -*-
|
|
|
|
|
|
def extras(*p):
|
|
return reqs('extras', *p)
|
|
|
|
# Celery specific
|
|
features = set([
|
|
'auth', 'cassandra', 'elasticsearch', 'memcache', 'pymemcache',
|
|
'couchbase', 'threads', 'eventlet', 'gevent', 'msgpack', 'yaml',
|
|
'redis', 'sqs', 'couchdb', 'riak', 'zookeeper',
|
|
'zeromq', 'sqlalchemy', 'librabbitmq', 'pyro', 'slmq', 'tblib', 'consul'
|
|
])
|
|
extras_require = dict((x, extras(x + '.txt')) for x in features)
|
|
extra['extras_require'] = extras_require
|
|
|
|
# -*- %%% -*-
|
|
|
|
setup(
|
|
name=NAME,
|
|
version=meta['VERSION'],
|
|
description=meta['doc'],
|
|
author=meta['author'],
|
|
author_email=meta['contact'],
|
|
url=meta['homepage'],
|
|
platforms=['any'],
|
|
license='BSD',
|
|
packages=find_packages(exclude=['ez_setup', 'tests', 'tests.*']),
|
|
include_package_data=False,
|
|
zip_safe=False,
|
|
install_requires=install_requires,
|
|
tests_require=reqs('test.txt'),
|
|
test_suite='nose.collector',
|
|
classifiers=classifiers,
|
|
entry_points=entrypoints,
|
|
long_description=long_description,
|
|
**extra)
|