123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- import os
- import sys
- import codecs
- import platform
- extra = {}
- tests_require = ["nose", "nose-cover3", "sqlalchemy", "mock"]
- is_py3k = sys.version_info >= (3, 0)
- if is_py3k:
- extra.update(use_2to3=True)
- elif sys.version_info < (2, 7):
- tests_require.append("unittest2")
- elif sys.version_info <= (2, 5):
- tests_require.append("simplejson")
- if sys.version_info < (2, 5):
- raise Exception("Celery requires Python 2.5 or higher.")
- try:
- from setuptools import setup, find_packages
- from setuptools.command.test import test
- 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
- # -- Parse meta
- import re
- re_meta = re.compile(r'__(\w+?)__\s*=\s*(.*)')
- re_vers = re.compile(r'VERSION\s*=\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__))
- meta_fh = open(os.path.join(here, "celery/__init__.py"))
- try:
- 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))
- finally:
- meta_fh.close()
- # --
- class quicktest(test):
- extra_env = dict(SKIP_RLIMITS=1, QUICKTEST=1)
- def run(self, *args, **kwargs):
- for env_name, env_value in self.extra_env.items():
- os.environ[env_name] = str(env_value)
- test.run(self, *args, **kwargs)
- install_requires = []
- try:
- import importlib # noqa
- except ImportError:
- install_requires.append("importlib")
- install_requires.extend([
- "anyjson>=0.3.1",
- "kombu>=1.4.3,<3.0.0",
- ])
- if is_py3k:
- install_requires.append("python-dateutil>=2.0.0")
- else:
- install_requires.append("python-dateutil>=1.5.0,<2.0.0")
- py_version = sys.version_info
- is_jython = sys.platform.startswith("java")
- is_pypy = hasattr(sys, "pypy_version_info")
- if sys.version_info < (2, 7):
- install_requires.append("ordereddict") # Replacement for the ordered dict
- if sys.version_info < (2, 6) and not (is_jython or is_pypy):
- install_requires.append("multiprocessing")
- if is_jython:
- install_requires.append("threadpool")
- install_requires.append("simplejson")
- 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"
- console_scripts = [
- 'celerybeat = celery.bin.celerybeat:main',
- 'camqadm = celery.bin.camqadm:main',
- 'celeryev = celery.bin.celeryev:main',
- 'celeryctl = celery.bin.celeryctl:main',
- 'celeryd-multi = celery.bin.celeryd_multi:main',
- ]
- if platform.system() == "Windows":
- console_scripts.append('celeryd = celery.bin.celeryd:windows_main')
- else:
- console_scripts.append('celeryd = celery.bin.celeryd:main')
- setup(
- name="celery",
- 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,
- cmdclass={"test": test,
- "quicktest": quicktest},
- test_suite="nose.collector",
- classifiers=[
- "Development Status :: 5 - Production/Stable",
- "Operating System :: OS Independent",
- "Environment :: No Input/Output (Daemon)",
- "Intended Audience :: Developers",
- "License :: OSI Approved :: BSD License",
- "Operating System :: POSIX",
- "Topic :: Communications",
- "Topic :: System :: Distributed Computing",
- "Topic :: Software Development :: Libraries :: Python Modules",
- "Programming Language :: Python",
- "Programming Language :: Python :: 2",
- "Programming Language :: Python :: 2.5",
- "Programming Language :: Python :: 2.6",
- "Programming Language :: Python :: 2.7",
- "Programming Language :: Python :: 3",
- ],
- entry_points={
- 'console_scripts': console_scripts,
- },
- long_description=long_description,
- **extra)
|