setup.py revision 12037:d28054ac6ec9
1#!/usr/bin/env python
2
3# Setup script for PyPI; use CMakeFile.txt to build extension modules
4
5from setuptools import setup
6from pybind11 import __version__
7import os
8
9# Prevent installation of pybind11 headers by setting
10# PYBIND11_USE_CMAKE.
11if os.environ.get('PYBIND11_USE_CMAKE'):
12    headers = []
13else:
14    headers = [
15        'include/pybind11/attr.h',
16        'include/pybind11/cast.h',
17        'include/pybind11/chrono.h',
18        'include/pybind11/class_support.h',
19        'include/pybind11/common.h',
20        'include/pybind11/complex.h',
21        'include/pybind11/descr.h',
22        'include/pybind11/eigen.h',
23        'include/pybind11/eval.h',
24        'include/pybind11/functional.h',
25        'include/pybind11/numpy.h',
26        'include/pybind11/operators.h',
27        'include/pybind11/options.h',
28        'include/pybind11/pybind11.h',
29        'include/pybind11/pytypes.h',
30        'include/pybind11/stl.h',
31        'include/pybind11/stl_bind.h',
32        'include/pybind11/typeid.h'
33    ]
34
35setup(
36    name='pybind11',
37    version=__version__,
38    description='Seamless operability between C++11 and Python',
39    author='Wenzel Jakob',
40    author_email='wenzel.jakob@epfl.ch',
41    url='https://github.com/wjakob/pybind11',
42    download_url='https://github.com/wjakob/pybind11/tarball/v' + __version__,
43    packages=['pybind11'],
44    license='BSD',
45    headers=headers,
46    classifiers=[
47        'Development Status :: 5 - Production/Stable',
48        'Intended Audience :: Developers',
49        'Topic :: Software Development :: Libraries :: Python Modules',
50        'Topic :: Utilities',
51        'Programming Language :: C++',
52        'Programming Language :: Python :: 2.7',
53        'Programming Language :: Python :: 3',
54        'Programming Language :: Python :: 3.2',
55        'Programming Language :: Python :: 3.3',
56        'Programming Language :: Python :: 3.4',
57        'Programming Language :: Python :: 3.5',
58        'Programming Language :: Python :: 3.6',
59        'License :: OSI Approved :: BSD License'
60    ],
61    keywords='C++11, Python bindings',
62    long_description="""pybind11 is a lightweight header-only library that
63exposes C++ types in Python and vice versa, mainly to create Python bindings of
64existing C++ code. Its goals and syntax are similar to the excellent
65Boost.Python by David Abrahams: to minimize boilerplate code in traditional
66extension modules by inferring type information using compile-time
67introspection.
68
69The main issue with Boost.Python-and the reason for creating such a similar
70project-is Boost. Boost is an enormously large and complex suite of utility
71libraries that works with almost every C++ compiler in existence. This
72compatibility has its cost: arcane template tricks and workarounds are
73necessary to support the oldest and buggiest of compiler specimens. Now that
74C++11-compatible compilers are widely available, this heavy machinery has
75become an excessively large and unnecessary dependency.
76
77Think of this library as a tiny self-contained version of Boost.Python with
78everything stripped away that isn't relevant for binding generation. Without
79comments, the core header files only require ~4K lines of code and depend on
80Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This
81compact implementation was possible thanks to some of the new C++11 language
82features (specifically: tuples, lambda functions and variadic templates). Since
83its creation, this library has grown beyond Boost.Python in many ways, leading
84to dramatically simpler binding code in many common situations.""")
85