setup.py now takes reqs from requirements/

This commit is contained in:
Ask Solem 2012-06-21 15:53:36 +01:00
parent 5cedbd24a1
commit 185348345f
4 changed files with 72 additions and 49 deletions

View File

@ -1,2 +1,2 @@
anyjson>=0.3.1
anyjson>=0.3.2
amqplib>=1.0.2

View File

@ -0,0 +1 @@
simplejson

View File

@ -2,7 +2,7 @@ nose
nose-cover3
unittest2>=0.5.0
coverage>=3.0
mock>=0.7.0
mock==dev
simplejson
PyYAML==3.09 # 3.10 dropped 2.4 support
msgpack-python==0.1.6 # 0.1.7 dropped 2.4 support

116
setup.py
View File

@ -3,20 +3,14 @@
import os
import sys
import codecs
import platform
extra = {}
tests_require = ["nose", "nose-cover3"]
if sys.version_info >= (3, 0):
is_py3k = sys.version_info[0] == 3
if is_py3k:
extra.update(use_2to3=True)
elif sys.version_info <= (2, 6):
tests_require.append("unittest2")
elif sys.version_info <= (2, 5):
tests_require.append("simplejson")
if sys.version_info < (2, 4):
raise Exception("Kombu requires Python 2.4 or higher.")
raise Exception('Kombu requires Python 2.4 or higher.')
try:
from setuptools import setup
@ -32,24 +26,25 @@ 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:])), )
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]), )
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, "kombu/__init__.py"))
meta_fh = open(os.path.join(here, 'kombu/__init__.py'))
try:
meta = {}
for line in meta_fh:
@ -67,7 +62,7 @@ packages, data_files = [], []
root_dir = os.path.dirname(__file__)
if root_dir != '':
os.chdir(root_dir)
src_dir = "kombu"
src_dir = 'kombu'
def fullsplit(path, result=None):
@ -87,55 +82,82 @@ for scheme in list(INSTALL_SCHEMES.values()):
for dirpath, dirnames, filenames in os.walk(src_dir):
# Ignore dirnames that start with '.'
for i, dirname in enumerate(dirnames):
if dirname.startswith("."):
if dirname.startswith('.'):
del dirnames[i]
for filename in filenames:
if filename.endswith(".py"):
if filename.endswith('.py'):
packages.append('.'.join(fullsplit(dirpath)))
else:
data_files.append([dirpath, [os.path.join(dirpath, f) for f in
filenames]])
if os.path.exists("README.rst"):
long_description = codecs.open('README.rst', "r", "utf-8").read()
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/kombu"
long_description = 'See http://pypi.python.org/pypi/kombu'
# -*- Installation Requires -*-
py_version = sys.version_info
is_jython = sys.platform.startswith('java')
is_pypy = hasattr(sys, 'pypy_version_info')
def strip_comments(l):
return l.split('#', 1)[0].strip()
def reqs(f):
return filter(None, [strip_comments(l) for l in open(
os.path.join(os.getcwd(), 'requirements', f)).readlines()])
install_requires = reqs('default.txt')
# -*- Tests Requires -*-
if is_py3k:
tests_require = reqs('test-py3k.txt')
elif is_jython:
tests_require = reqs('test-jython.txt')
elif is_pypy:
tests_require = reqs('test-pypy.txt')
else:
tests_require = reqs('test.txt')
if py_version[0:2] == (2, 5):
tests_require.extend('test-py25.txt')
setup(
name='kombu',
version=meta["VERSION"],
description=meta["doc"],
author=meta["author"],
author_email=meta["contact"],
url=meta["homepage"],
platforms=["any"],
version=meta['VERSION'],
description=meta['doc'],
author=meta['author'],
author_email=meta['contact'],
url=meta['homepage'],
platforms=['any'],
packages=packages,
data_files=data_files,
zip_safe=False,
test_suite="nose.collector",
install_requires=[
"anyjson>=0.3.1",
"amqplib>=1.0.2",
],
test_suite='nose.collector',
install_requires=install_requires,
tests_require=tests_require,
classifiers=[
"Development Status :: 5 - Production/Stable",
"License :: OSI Approved :: BSD License",
"Operating System :: OS Independent",
"Programming Language :: Python",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 2.7",
"Programming Language :: Python :: 2.6",
"Programming Language :: Python :: 2.5",
"Programming Language :: Python :: 2",
"Programming Language :: Python :: Implementation :: CPython",
"Programming Language :: Python :: Implementation :: PyPy",
"Programming Language :: Python :: Implementation :: Jython",
"Intended Audience :: Developers",
"Topic :: Communications",
"Topic :: System :: Distributed Computing",
"Topic :: System :: Networking",
"Topic :: Software Development :: Libraries :: Python Modules",
'Development Status :: 5 - Production/Stable',
'License :: OSI Approved :: BSD License',
'Operating System :: OS Independent',
'Programming Language :: Python',
'Programming Language :: Python :: 3',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 2.6',
'Programming Language :: Python :: 2.5',
'Programming Language :: Python :: 2',
'Programming Language :: Python :: Implementation :: CPython',
'Programming Language :: Python :: Implementation :: PyPy',
'Programming Language :: Python :: Implementation :: Jython',
'Intended Audience :: Developers',
'Topic :: Communications',
'Topic :: System :: Distributed Computing',
'Topic :: System :: Networking',
'Topic :: Software Development :: Libraries :: Python Modules',
],
long_description=long_description,
**extra)