12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- #!/usr/bin/python
- # Setup file for dulwich
- # Copyright (C) 2008-2011 Jelmer Vernooij <jelmer@samba.org>
- try:
- from setuptools import setup, Extension
- except ImportError:
- from distutils.core import setup, Extension
- from distutils.core import Distribution
- dulwich_version_string = '0.9.8'
- include_dirs = []
- # Windows MSVC support
- import os
- import sys
- if sys.platform == 'win32':
- include_dirs.append('dulwich')
- class DulwichDistribution(Distribution):
- def is_pure(self):
- if self.pure:
- return True
- def has_ext_modules(self):
- return not self.pure and not '__pypy__' in sys.modules
- global_options = Distribution.global_options + [
- ('pure', None, "use pure Python code instead of C "
- "extensions (slower on CPython)")]
- pure = False
- if sys.platform == 'darwin' and os.path.exists('/usr/bin/xcodebuild'):
- # XCode 4.0 dropped support for ppc architecture, which is hardcoded in
- # distutils.sysconfig
- import subprocess
- p = subprocess.Popen(
- ['/usr/bin/xcodebuild', '-version'], stdout=subprocess.PIPE,
- stderr=subprocess.PIPE, env={})
- out, err = p.communicate()
- for l in out.splitlines():
- l = l.decode("utf8")
- # Also parse only first digit, because 3.2.1 can't be parsed nicely
- if l.startswith('Xcode') and int(l.split()[1].split('.')[0]) >= 4:
- os.environ['ARCHFLAGS'] = ''
- setup(name='dulwich',
- description='Python Git Library',
- keywords='git',
- version=dulwich_version_string,
- url='https://samba.org/~jelmer/dulwich',
- license='GPLv2 or later',
- author='Jelmer Vernooij',
- author_email='jelmer@samba.org',
- long_description="""
- Python implementation of the Git file formats and protocols,
- without the need to have git installed.
- All functionality is available in pure Python. Optional
- C extensions can be built for improved performance.
- The project is named after the part of London that Mr. and Mrs. Git live in
- in the particular Monty Python sketch.
- """,
- packages=['dulwich', 'dulwich.tests', 'dulwich.tests.compat', 'dulwich.contrib'],
- scripts=['bin/dulwich', 'bin/dul-receive-pack', 'bin/dul-upload-pack'],
- ext_modules=[
- Extension('dulwich._objects', ['dulwich/_objects.c'],
- include_dirs=include_dirs),
- Extension('dulwich._pack', ['dulwich/_pack.c'],
- include_dirs=include_dirs),
- Extension('dulwich._diff_tree', ['dulwich/_diff_tree.c'],
- include_dirs=include_dirs),
- ],
- test_suite='dulwich.tests.test_suite',
- tests_require=['fastimport', 'mock', 'gevent', 'geventhttpclient'],
- distclass=DulwichDistribution,
- include_package_data=True,
- use_2to3=True,
- convert_2to3_doctests=['../docs/*', '../docs/tutorial/*', ],
- )
|