#!/usr/bin/env python # -*- coding: utf-8 -*- try: from setuptools import setup, find_packages from setuptools.command.test import test is_setuptools = True except ImportError: raise from ez_setup import use_setuptools use_setuptools() from setuptools import setup, find_packages # noqa from setuptools.command.test import test # noqa is_setuptools = False import os import sys import codecs CELERY_COMPAT_PROGRAMS = int(os.environ.get('CELERY_COMPAT_PROGRAMS', 1)) if sys.version_info < (2, 6): raise Exception('Celery 3.1 requires Python 2.6 or higher.') 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.6 Programming Language :: Python :: 2.7 Programming Language :: Python :: 3 Programming Language :: Python :: 3.3 Programming Language :: Python :: 3.4 Programming Language :: Python :: Implementation :: CPython Programming Language :: Python :: Implementation :: PyPy Programming Language :: Python :: Implementation :: Jython Operating System :: OS Independent Operating System :: POSIX Operating System :: Microsoft :: Windows Operating System :: MacOS :: MacOS X """ classifiers = [s.strip() for s in classes.split('\n') if s] PY3 = sys.version_info[0] == 3 JYTHON = sys.platform.startswith('java') PYPY = hasattr(sys, 'pypy_version_info') # -*- Distribution Meta -*- import re re_meta = re.compile(r'__(\w+?)__\s*=\s*(.*)') re_vers = re.compile(r'VERSION\s*=.*?\((.*?)\)') re_doc = re.compile(r'^"""(.+?)"""') rq = lambda s: 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 -*- py_version = sys.version_info def strip_comments(l): return l.split('#', 1)[0].strip() def reqs(*f): return [ r for r in ( strip_comments(l) for l in open( os.path.join(os.getcwd(), 'requirements', *f)).readlines() ) if r] install_requires = reqs('default.txt') if JYTHON: install_requires.extend(reqs('jython.txt')) # -*- Tests Requires -*- tests_require = reqs('test3.txt' if PY3 else 'test.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', ] if CELERY_COMPAT_PROGRAMS: console_scripts.extend([ 'celeryd = celery.__main__:_compat_worker', 'celerybeat = celery.__main__:_compat_beat', 'celeryd-multi = celery.__main__:_compat_multi', ]) if is_setuptools: extras = lambda *p: reqs('extras', *p) # Celery specific specific_list = ['auth', 'cassandra', 'memcache', 'couchbase', 'threads', 'eventlet', 'gevent', 'msgpack', 'yaml', 'redis', 'mongodb', 'sqs', 'couchdb', 'beanstalk', 'zookeeper', 'zeromq', 'sqlalchemy', 'librabbitmq', 'pyro', 'slmq'] extras_require = dict((x, extras(x + '.txt')) for x in specific_list) 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.*']), zip_safe=False, install_requires=install_requires, tests_require=tests_require, test_suite='nose.collector', classifiers=classifiers, entry_points=entrypoints, long_description=long_description, **extra)