blob: 517818e7207fff779f92567e09c8ddb6074b4fab [file] [log] [blame]
Wenzel Jakob929fd7e2015-10-15 18:24:12 +02001#!/usr/bin/env python
2
Dean Moldovana0c1ccf2016-08-12 13:50:00 +02003# Setup script for PyPI; use CMakeFile.txt to build extension modules
Wenzel Jakob929fd7e2015-10-15 18:24:12 +02004
5from setuptools import setup
Wenzel Jakob4f972c02016-03-01 10:36:10 +01006from pybind11 import __version__
Sylvain Corlayd5ce82b2017-02-14 13:16:14 +01007import os
Wenzel Jakob929fd7e2015-10-15 18:24:12 +02008
Sylvain Corlayd5ce82b2017-02-14 13:16:14 +01009# Prevent installation of pybind11 headers by setting
10# PYBIND11_USE_CMAKE.
11if os.environ.get('PYBIND11_USE_CMAKE'):
12 headers = []
13else:
14 headers = [
Wenzel Jakob48548ea2016-01-17 22:36:44 +010015 'include/pybind11/attr.h',
Jason Rhinelander2b941b32017-05-07 12:19:19 -040016 'include/pybind11/buffer_info.h',
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020017 'include/pybind11/cast.h',
Alessandro Bacchini9f13a302016-12-01 15:22:17 +010018 'include/pybind11/chrono.h',
Dean Moldovanc91f8bd2017-02-13 18:11:24 +010019 'include/pybind11/class_support.h',
Alessandro Bacchini9f13a302016-12-01 15:22:17 +010020 'include/pybind11/common.h',
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020021 'include/pybind11/complex.h',
Wenzel Jakob678d7872016-01-17 22:36:41 +010022 'include/pybind11/descr.h',
Wenzel Jakob9e0a0562016-05-05 20:33:54 +020023 'include/pybind11/eigen.h',
Alessandro Bacchini9f13a302016-12-01 15:22:17 +010024 'include/pybind11/eval.h',
25 'include/pybind11/functional.h',
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020026 'include/pybind11/numpy.h',
Alessandro Bacchini9f13a302016-12-01 15:22:17 +010027 'include/pybind11/operators.h',
28 'include/pybind11/options.h',
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020029 'include/pybind11/pybind11.h',
Alessandro Bacchini9f13a302016-12-01 15:22:17 +010030 'include/pybind11/pytypes.h',
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020031 'include/pybind11/stl.h',
Wenzel Jakob25c03ce2016-05-15 20:50:38 +020032 'include/pybind11/stl_bind.h',
Wenzel Jakob2723a382017-01-01 17:14:27 +010033 'include/pybind11/typeid.h'
Sylvain Corlayd5ce82b2017-02-14 13:16:14 +010034 ]
35
36setup(
37 name='pybind11',
38 version=__version__,
39 description='Seamless operability between C++11 and Python',
40 author='Wenzel Jakob',
41 author_email='wenzel.jakob@epfl.ch',
42 url='https://github.com/wjakob/pybind11',
43 download_url='https://github.com/wjakob/pybind11/tarball/v' + __version__,
44 packages=['pybind11'],
45 license='BSD',
46 headers=headers,
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020047 classifiers=[
48 'Development Status :: 5 - Production/Stable',
49 'Intended Audience :: Developers',
50 'Topic :: Software Development :: Libraries :: Python Modules',
51 'Topic :: Utilities',
52 'Programming Language :: C++',
53 'Programming Language :: Python :: 2.7',
54 'Programming Language :: Python :: 3',
55 'Programming Language :: Python :: 3.2',
56 'Programming Language :: Python :: 3.3',
57 'Programming Language :: Python :: 3.4',
Wenzel Jakobb456ec72015-10-15 22:43:55 +020058 'Programming Language :: Python :: 3.5',
Wenzel Jakob2723a382017-01-01 17:14:27 +010059 'Programming Language :: Python :: 3.6',
60 'License :: OSI Approved :: BSD License'
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020061 ],
62 keywords='C++11, Python bindings',
Wenzel Jakob2723a382017-01-01 17:14:27 +010063 long_description="""pybind11 is a lightweight header-only library that
64exposes C++ types in Python and vice versa, mainly to create Python bindings of
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020065existing C++ code. Its goals and syntax are similar to the excellent
Wenzel Jakob2723a382017-01-01 17:14:27 +010066Boost.Python by David Abrahams: to minimize boilerplate code in traditional
67extension modules by inferring type information using compile-time
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020068introspection.
69
Wenzel Jakob0f294e22017-01-04 15:17:18 +010070The main issue with Boost.Python-and the reason for creating such a similar
71project-is Boost. Boost is an enormously large and complex suite of utility
Wenzel Jakob929fd7e2015-10-15 18:24:12 +020072libraries that works with almost every C++ compiler in existence. This
73compatibility has its cost: arcane template tricks and workarounds are
74necessary to support the oldest and buggiest of compiler specimens. Now that
75C++11-compatible compilers are widely available, this heavy machinery has
76become an excessively large and unnecessary dependency.
77
78Think of this library as a tiny self-contained version of Boost.Python with
Wenzel Jakob48548ea2016-01-17 22:36:44 +010079everything stripped away that isn't relevant for binding generation. Without
Wenzel Jakob2723a382017-01-01 17:14:27 +010080comments, the core header files only require ~4K lines of code and depend on
81Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This
82compact implementation was possible thanks to some of the new C++11 language
83features (specifically: tuples, lambda functions and variadic templates). Since
84its creation, this library has grown beyond Boost.Python in many ways, leading
85to dramatically simpler binding code in many common situations.""")