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