setup.py 5.07 KB
Newer Older
1
#!/usr/bin/env python
2
# -*- coding: utf-8 -*-
3

Dean Moldovan's avatar
Dean Moldovan committed
4
# Setup script for PyPI; use CMakeFile.txt to build extension modules
5
6

from setuptools import setup
7
from distutils.command.install_headers import install_headers
8
from distutils.command.build_py import build_py
9
from pybind11 import __version__
10
import os
11

12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package_data = [
    'include/pybind11/detail/class.h',
    'include/pybind11/detail/common.h',
    'include/pybind11/detail/descr.h',
    'include/pybind11/detail/init.h',
    'include/pybind11/detail/internals.h',
    'include/pybind11/detail/typeid.h',
    'include/pybind11/attr.h',
    'include/pybind11/buffer_info.h',
    'include/pybind11/cast.h',
    'include/pybind11/chrono.h',
    'include/pybind11/common.h',
    'include/pybind11/complex.h',
    'include/pybind11/eigen.h',
    'include/pybind11/embed.h',
    'include/pybind11/eval.h',
    'include/pybind11/functional.h',
    'include/pybind11/iostream.h',
    'include/pybind11/numpy.h',
    'include/pybind11/operators.h',
    'include/pybind11/options.h',
    'include/pybind11/pybind11.h',
    'include/pybind11/pytypes.h',
    'include/pybind11/stl.h',
    'include/pybind11/stl_bind.h',
]

39
40
41
42
43
# Prevent installation of pybind11 headers by setting
# PYBIND11_USE_CMAKE.
if os.environ.get('PYBIND11_USE_CMAKE'):
    headers = []
else:
44
    headers = package_data
45

46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61

class InstallHeaders(install_headers):
    """Use custom header installer because the default one flattens subdirectories"""
    def run(self):
        if not self.distribution.headers:
            return

        for header in self.distribution.headers:
            subdir = os.path.dirname(os.path.relpath(header, 'include/pybind11'))
            install_dir = os.path.join(self.install_dir, subdir)
            self.mkpath(install_dir)

            (out, _) = self.copy_file(header, install_dir)
            self.outfiles.append(out)


62
63
64
65
66
67
68
69
70
# Install the headers inside the package as well
class BuildPy(build_py):
    def build_package_data(self):
        build_py.build_package_data(self)
        for header in package_data:
            target = os.path.join(self.build_lib, 'pybind11', header)
            self.mkpath(os.path.dirname(target))
            self.copy_file(header, target, preserve_mode=False)

71
72
73
74
75
76
77
    def get_outputs(self, include_bytecode=1):
        outputs = build_py.get_outputs(self, include_bytecode=include_bytecode)
        for header in package_data:
            target = os.path.join(self.build_lib, 'pybind11', header)
            outputs.append(target)
        return outputs

78

79
80
81
82
83
84
setup(
    name='pybind11',
    version=__version__,
    description='Seamless operability between C++11 and Python',
    author='Wenzel Jakob',
    author_email='wenzel.jakob@epfl.ch',
Maciek Starzyk's avatar
Maciek Starzyk committed
85
86
    url='https://github.com/pybind/pybind11',
    download_url='https://github.com/pybind/pybind11/tarball/v' + __version__,
87
88
89
    packages=['pybind11'],
    license='BSD',
    headers=headers,
90
91
    zip_safe=False,
    cmdclass=dict(install_headers=InstallHeaders, build_py=BuildPy),
92
93
94
95
96
97
98
99
100
101
102
    classifiers=[
        'Development Status :: 5 - Production/Stable',
        'Intended Audience :: Developers',
        'Topic :: Software Development :: Libraries :: Python Modules',
        'Topic :: Utilities',
        'Programming Language :: C++',
        'Programming Language :: Python :: 2.7',
        'Programming Language :: Python :: 3',
        'Programming Language :: Python :: 3.2',
        'Programming Language :: Python :: 3.3',
        'Programming Language :: Python :: 3.4',
103
        'Programming Language :: Python :: 3.5',
Wenzel Jakob's avatar
Wenzel Jakob committed
104
105
        'Programming Language :: Python :: 3.6',
        'License :: OSI Approved :: BSD License'
106
107
    ],
    keywords='C++11, Python bindings',
Wenzel Jakob's avatar
Wenzel Jakob committed
108
109
    long_description="""pybind11 is a lightweight header-only library that
exposes C++ types in Python and vice versa, mainly to create Python bindings of
110
existing C++ code. Its goals and syntax are similar to the excellent
Wenzel Jakob's avatar
Wenzel Jakob committed
111
112
Boost.Python by David Abrahams: to minimize boilerplate code in traditional
extension modules by inferring type information using compile-time
113
114
introspection.

115
116
The main issue with Boost.Python-and the reason for creating such a similar
project-is Boost. Boost is an enormously large and complex suite of utility
117
118
119
120
121
122
123
libraries that works with almost every C++ compiler in existence. This
compatibility has its cost: arcane template tricks and workarounds are
necessary to support the oldest and buggiest of compiler specimens. Now that
C++11-compatible compilers are widely available, this heavy machinery has
become an excessively large and unnecessary dependency.

Think of this library as a tiny self-contained version of Boost.Python with
Wenzel Jakob's avatar
Wenzel Jakob committed
124
everything stripped away that isn't relevant for binding generation. Without
Wenzel Jakob's avatar
Wenzel Jakob committed
125
126
127
128
129
130
comments, the core header files only require ~4K lines of code and depend on
Python (2.7 or 3.x, or PyPy2.7 >= 5.7) and the C++ standard library. This
compact implementation was possible thanks to some of the new C++11 language
features (specifically: tuples, lambda functions and variadic templates). Since
its creation, this library has grown beyond Boost.Python in many ways, leading
to dramatically simpler binding code in many common situations.""")