#!/usr/bin/python
-# Setup file for bzr-git
-# Copyright (C) 2008-2009 Jelmer Vernooij <jelmer@samba.org>
+# Setup file for dulwich
+# Copyright (C) 2008-2011 Jelmer Vernooij <jelmer@samba.org>
try:
from setuptools import setup, Extension
+ has_setuptools = True
except ImportError:
from distutils.core import setup, Extension
+ has_setuptools = False
from distutils.core import Distribution
-dulwich_version_string = '0.5.0'
+dulwich_version_string = '0.9.5'
include_dirs = []
# Windows MSVC support
+import os
import sys
if sys.platform == 'win32':
include_dirs.append('dulwich')
-ext_modules = [
- Extension('dulwich._objects', ['dulwich/_objects.c'],
- include_dirs=include_dirs),
- Extension('dulwich._pack', ['dulwich/_pack.c'],
- include_dirs=include_dirs),
- ]
-
-try:
- from setuptools import Feature
-except ImportError:
- speedups = None
- mandatory_ext_modules = ext_modules
-else:
- mandatory_ext_modules = []
- speedups = Feature(
- "optional C speed-enhancements",
- standard = True,
- ext_modules=ext_modules,
- )
+class DulwichDistribution(Distribution):
-class dulwichDistribution(Distribution):
def is_pure(self):
if self.pure:
return True
+
def has_ext_modules(self):
- if self.pure:
- return False
-
-dulwichDistribution.pure = 0
-dulwichDistribution.global_options.append(('pure', None, "use pure (slow) Python "
-"code instead of C extensions"))
-
+ 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():
+ # 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_kwargs = {}
+
+if has_setuptools:
+ setup_kwargs['test_suite'] = 'dulwich.tests.test_suite'
setup(name='dulwich',
- description='Pure-Python Git Library',
+ description='Python Git Library',
keywords='git',
version=dulwich_version_string,
- url='http://samba.org/~jelmer/dulwich',
- download_url='http://samba.org/~jelmer/dulwich/dulwich-%s.tar.gz' % dulwich_version_string,
+ url='https://samba.org/~jelmer/dulwich',
license='GPLv2 or later',
author='Jelmer Vernooij',
author_email='jelmer@samba.org',
long_description="""
- Simple Pure-Python implementation of the Git file formats and
- protocols. Dulwich is the place where Mr. and Mrs. Git live
- in one of the Monty Python sketches.
+ 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'],
- scripts=['bin/dulwich', 'bin/dul-daemon', 'bin/dul-web'],
- features = {'speedups': speedups},
- ext_modules = mandatory_ext_modules,
- distclass=dulwichDistribution,
+ packages=['dulwich', 'dulwich.tests', 'dulwich.tests.compat'],
+ scripts=['bin/dulwich', 'bin/dul-daemon', 'bin/dul-web', '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),
+ ],
+ distclass=DulwichDistribution,
+ **setup_kwargs
)