ext: Fix undefined macro in pybind
[gem5.git] / ext / pybind11 / setup.py
1 #!/usr/bin/env python
2
3 # Setup script for PyPI; use CMakeFile.txt to build extension modules
4
5 from setuptools import setup
6 from pybind11 import __version__
7
8 setup(
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=[
19 'include/pybind11/attr.h',
20 'include/pybind11/cast.h',
21 'include/pybind11/chrono.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',
35 'include/pybind11/typeid.h',
36 ],
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',
49 'License :: OSI Approved :: BSD License',
50 ],
51 keywords='C++11, Python bindings',
52 long_description="""pybind11 is a lightweight header library that exposes
53 C++ types in Python and vice versa, mainly to create Python bindings of
54 existing C++ code. Its goals and syntax are similar to the excellent
55 Boost.Python library by David Abrahams: to minimize boilerplate code in
56 traditional extension modules by inferring type information using compile-time
57 introspection.
58
59 The main issue with Boost.Python-and the reason for creating such a similar
60 project-is Boost. Boost is an enormously large and complex suite of utility
61 libraries that works with almost every C++ compiler in existence. This
62 compatibility has its cost: arcane template tricks and workarounds are
63 necessary to support the oldest and buggiest of compiler specimens. Now that
64 C++11-compatible compilers are widely available, this heavy machinery has
65 become an excessively large and unnecessary dependency.
66
67 Think of this library as a tiny self-contained version of Boost.Python with
68 everything stripped away that isn't relevant for binding generation. Without
69 comments, the core header files only require ~2.5K lines of code and depend on
70 Python (2.7 or 3.x) and the C++ standard library. This compact implementation
71 was possible thanks to some of the new C++11 language features (specifically:
72 tuples, lambda functions and variadic templates). Since its creation, this
73 library has grown beyond Boost.Python in many ways, leading to dramatically
74 simpler binding code in many common situations.""")