109 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Python
		
	
	
		
		
			
		
	
	
			109 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Python
		
	
	
|  | #!/usr/bin/env python | ||
|  | 
 | ||
|  | # Setup script for PyPI; use CMakeFile.txt to build extension modules | ||
|  | 
 | ||
|  | from setuptools import setup | ||
|  | from distutils.command.install_headers import install_headers | ||
|  | from pybind11 import __version__ | ||
|  | import os | ||
|  | 
 | ||
|  | # Prevent installation of pybind11 headers by setting | ||
|  | # PYBIND11_USE_CMAKE. | ||
|  | if os.environ.get('PYBIND11_USE_CMAKE'): | ||
|  |     headers = [] | ||
|  | else: | ||
|  |     headers = [ | ||
|  |         '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', | ||
|  |     ] | ||
|  | 
 | ||
|  | 
 | ||
|  | 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) | ||
|  | 
 | ||
|  | 
 | ||
|  | setup( | ||
|  |     name='pybind11', | ||
|  |     version=__version__, | ||
|  |     description='Seamless operability between C++11 and Python', | ||
|  |     author='Wenzel Jakob', | ||
|  |     author_email='wenzel.jakob@epfl.ch', | ||
|  |     url='https://github.com/pybind/pybind11', | ||
|  |     download_url='https://github.com/pybind/pybind11/tarball/v' + __version__, | ||
|  |     packages=['pybind11'], | ||
|  |     license='BSD', | ||
|  |     headers=headers, | ||
|  |     cmdclass=dict(install_headers=InstallHeaders), | ||
|  |     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', | ||
|  |         'Programming Language :: Python :: 3.5', | ||
|  |         'Programming Language :: Python :: 3.6', | ||
|  |         'License :: OSI Approved :: BSD License' | ||
|  |     ], | ||
|  |     keywords='C++11, Python bindings', | ||
|  |     long_description="""pybind11 is a lightweight header-only library that
 | ||
|  | exposes C++ types in Python and vice versa, mainly to create Python bindings of | ||
|  | existing C++ code. Its goals and syntax are similar to the excellent | ||
|  | Boost.Python by David Abrahams: to minimize boilerplate code in traditional | ||
|  | extension modules by inferring type information using compile-time | ||
|  | introspection. | ||
|  | 
 | ||
|  | 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 | ||
|  | 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 | ||
|  | everything stripped away that isn't relevant for binding generation. Without | ||
|  | 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.""")
 |