setup.py 3.53 KB
Newer Older
1
2
#!/usr/bin/env python

Dean Moldovan's avatar
Dean Moldovan committed
3
# Setup script for PyPI; use CMakeFile.txt to build extension modules
4
5

from setuptools import setup
6
from pybind11 import __version__
7
import os
8

9
10
11
12
13
14
# Prevent installation of pybind11 headers by setting
# PYBIND11_USE_CMAKE.
if os.environ.get('PYBIND11_USE_CMAKE'):
    headers = []
else:
    headers = [
Wenzel Jakob's avatar
Wenzel Jakob committed
15
        'include/pybind11/attr.h',
16
        'include/pybind11/buffer_info.h',
17
        'include/pybind11/cast.h',
18
        'include/pybind11/chrono.h',
19
        'include/pybind11/class_support.h',
20
        'include/pybind11/common.h',
21
        'include/pybind11/complex.h',
22
        'include/pybind11/descr.h',
23
        'include/pybind11/eigen.h',
24
25
        'include/pybind11/eval.h',
        'include/pybind11/functional.h',
26
        'include/pybind11/numpy.h',
27
28
        'include/pybind11/operators.h',
        'include/pybind11/options.h',
29
        'include/pybind11/pybind11.h',
30
        'include/pybind11/pytypes.h',
31
        'include/pybind11/stl.h',
32
        'include/pybind11/stl_bind.h',
Wenzel Jakob's avatar
Wenzel Jakob committed
33
        'include/pybind11/typeid.h'
34
35
36
37
38
39
40
41
42
43
44
45
46
    ]

setup(
    name='pybind11',
    version=__version__,
    description='Seamless operability between C++11 and Python',
    author='Wenzel Jakob',
    author_email='wenzel.jakob@epfl.ch',
    url='https://github.com/wjakob/pybind11',
    download_url='https://github.com/wjakob/pybind11/tarball/v' + __version__,
    packages=['pybind11'],
    license='BSD',
    headers=headers,
47
48
49
50
51
52
53
54
55
56
57
    classifiers=[
        'Development Status :: 5 - Production/Stable',
        'Intended Audience :: Developers',
        'Topic :: Software Development :: Libraries :: Python Modules',
        'Topic :: Utilities',
        'Programming Language :: C++',
        'Programming Language :: Python :: 2.7',
        'Programming Language :: Python :: 3',
        'Programming Language :: Python :: 3.2',
        'Programming Language :: Python :: 3.3',
        'Programming Language :: Python :: 3.4',
58
        'Programming Language :: Python :: 3.5',
Wenzel Jakob's avatar
Wenzel Jakob committed
59
60
        'Programming Language :: Python :: 3.6',
        'License :: OSI Approved :: BSD License'
61
62
    ],
    keywords='C++11, Python bindings',
Wenzel Jakob's avatar
Wenzel Jakob committed
63
64
    long_description="""pybind11 is a lightweight header-only library that
exposes C++ types in Python and vice versa, mainly to create Python bindings of
65
existing C++ code. Its goals and syntax are similar to the excellent
Wenzel Jakob's avatar
Wenzel Jakob committed
66
67
Boost.Python by David Abrahams: to minimize boilerplate code in traditional
extension modules by inferring type information using compile-time
68
69
introspection.

70
71
The main issue with Boost.Python-and the reason for creating such a similar
project-is Boost. Boost is an enormously large and complex suite of utility
72
73
74
75
76
77
78
libraries that works with almost every C++ compiler in existence. This
compatibility has its cost: arcane template tricks and workarounds are
necessary to support the oldest and buggiest of compiler specimens. Now that
C++11-compatible compilers are widely available, this heavy machinery has
become an excessively large and unnecessary dependency.

Think of this library as a tiny self-contained version of Boost.Python with
Wenzel Jakob's avatar
Wenzel Jakob committed
79
everything stripped away that isn't relevant for binding generation. Without
Wenzel Jakob's avatar
Wenzel Jakob committed
80
81
82
83
84
85
comments, the core header files only require ~4K lines of code and depend on
Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This
compact implementation was possible thanks to some of the new C++11 language
features (specifically: tuples, lambda functions and variadic templates). Since
its creation, this library has grown beyond Boost.Python in many ways, leading
to dramatically simpler binding code in many common situations.""")