MissingObjectFinder: minor cleanup: 80 chars, others.
[jelmer/dulwich-libgit2.git] / setup.py
index b2cb3a0cea79f74106be2c88d5e5bf262b6e1b76..c71c96161f6d052e4ca35b4f94dcd78efed4abd8 100755 (executable)
--- a/setup.py
+++ b/setup.py
@@ -1,13 +1,14 @@
 #!/usr/bin/python
-# Setup file for bzr-git
-# Copyright (C) 2008-2009 Jelmer Vernooij <jelmer@samba.org>
+# Setup file for dulwich
+# Copyright (C) 2008-2010 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.5.0'
+dulwich_version_string = '0.6.2'
 
 include_dirs = []
 # Windows MSVC support
@@ -15,27 +16,23 @@ 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):
 
+    def is_pure(self):
+        if self.pure:
+            return True
 
+    def has_ext_modules(self):
+        return not self.pure
+
+    global_options = Distribution.global_options + [
+        ('pure', None, 
+            "use pure (slower) Python code instead of C extensions")]
+
+    pure = False
+
+        
 setup(name='dulwich',
       description='Pure-Python Git Library',
       keywords='git',
@@ -52,6 +49,11 @@ setup(name='dulwich',
       """,
       packages=['dulwich', 'dulwich.tests'],
       scripts=['bin/dulwich', 'bin/dul-daemon', 'bin/dul-web'],
-      features = {'speedups': speedups},
-      ext_modules = mandatory_ext_modules,
+      ext_modules = [
+          Extension('dulwich._objects', ['dulwich/_objects.c'],
+                    include_dirs=include_dirs),
+          Extension('dulwich._pack', ['dulwich/_pack.c'],
+              include_dirs=include_dirs),
+          ],
+      distclass=DulwichDistribution,
       )