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.""")
|
| |