X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-afs.git/blobdiff_plain/2d2104b92ce4f472ade76c8fbb737b1c9028f8ea..f95acfabee62680cab0d953596cc7539585caff8:/setup.py diff --git a/setup.py b/setup.py index 6dc758c..2a92096 100755 --- a/setup.py +++ b/setup.py @@ -1,8 +1,8 @@ #!/usr/bin/python -from setuptools import setup, find_packages +from distutils.core import setup from distutils.extension import Extension -from Pyrex.Distutils import build_ext +from Cython.Distutils import build_ext import sys import os @@ -13,9 +13,26 @@ for root in ['/Library/OpenAFS/Tools', if os.path.exists('%s/include/afs/afs.h' % root): break -include_dirs = ['%s/include' % root] +include_dirs = [os.path.join(os.path.dirname(__file__), 'afs'), + '%s/include' % root] library_dirs = ['%s/lib' % root, '%s/lib/afs' % root] +if os.path.exists('%s/lib/libafsauthent_pic.a' % root): + suffix = '_pic' +else: + suffix = '' +libraries = ['afsauthent%s' % suffix, 'afsrpc%s' % suffix, 'resolv'] +define_macros = [('AFS_PTHREAD_ENV', None)] + +def PyAFSExtension(module, *args, **kwargs): + kwargs.setdefault('libraries', []).extend(libraries) + kwargs.setdefault('include_dirs', []).extend(include_dirs) + kwargs.setdefault('library_dirs', []).extend(library_dirs) + kwargs.setdefault('define_macros', []).extend(define_macros) + return Extension(module, + ["%s.pyx" % module.replace('.', '/')], + *args, + **kwargs) setup( name="PyAFS", @@ -23,16 +40,14 @@ setup( description="PyAFS - Python bindings for AFS", author="Evan Broder", author_email="broder@mit.edu", - license="MIT", - requires=['Pyrex'], - packages=find_packages(), + license="GPL", + requires=['Cython'], + packages=['afs', 'afs.tests'], ext_modules=[ - Extension("afs._pts", - ["afs/_pts.pyx"], - libraries=['bos', 'volser', 'vldb', 'afsrpc', 'afsauthent', - 'cmd', 'usd', 'audit'], - include_dirs=include_dirs, - library_dirs=library_dirs) + PyAFSExtension("afs.afs"), + PyAFSExtension("afs._acl"), + PyAFSExtension("afs._fs"), + PyAFSExtension("afs._pts", libraries=['krb5']), ], cmdclass= {"build_ext": build_ext} )