add setup.py to build python version

This commit is contained in:
maxbachmann 2020-02-29 18:17:00 +01:00
parent d0f2de09e1
commit cb84c0521c
5 changed files with 136 additions and 3 deletions

5
.gitignore vendored
View File

@ -1 +1,4 @@
.vscode/
.vscode/
*.data
*.so
test.py

1
VERSION Normal file
View File

@ -0,0 +1 @@
0.0.1

View File

@ -55,7 +55,7 @@ uint8_t full_ratio(const std::string &query, const std::string &choice,
}
uint8_t partial_ratio(const std::string &query, const std::string &choice,
/*uint8_t partial_ratio(const std::string &query, const std::string &choice,
uint8_t partial_scale, uint8_t score_cutoff)
{
float sratio = normalized_levenshtein(query, choice);
@ -69,7 +69,7 @@ uint8_t partial_ratio(const std::string &query, const std::string &choice,
}
}
return static_cast<uint8_t>(std::round(sratio * 100.0));
}
}*/
uint8_t ratio(const std::string &query, const std::string &choice,

16
python/rapidfuzz.cpp Normal file
View File

@ -0,0 +1,16 @@
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>
#include "process.hpp"
PYBIND11_MODULE(rapidfuzz, m) {
m.doc() = R"pbdoc(
rapid string matching library
)pbdoc";
m.def("extract_one", &extract_one, R"pbdoc(
Find the best match in a list of matches
)pbdoc");
m.attr("__version__") = VERSION_INFO;
}

113
setup.py Normal file
View File

@ -0,0 +1,113 @@
from setuptools import setup, Extension
from setuptools.command.build_ext import build_ext
import sys
import setuptools
with open("VERSION", "r") as version_file:
version = version_file.read().strip()
class get_pybind_include(object):
"""Helper class to determine the pybind11 include path
The purpose of this class is to postpone importing pybind11
until it is actually installed, so that the ``get_include()``
method can be invoked. """
def __init__(self, user=False):
self.user = user
def __str__(self):
import pybind11
return pybind11.get_include(self.user)
ext_modules = [
Extension(
'rapidfuzz',
['python/rapidfuzz.cpp'],
include_dirs=[
# Path to pybind11 headers
get_pybind_include(),
get_pybind_include(user=True),
"cpp"
],
extra_compile_args = ["-O3"],
language='c++'
),
]
# As of Python 3.6, CCompiler has a `has_flag` method.
# cf http://bugs.python.org/issue26689
def has_flag(compiler, flagname):
"""Return a boolean indicating whether a flag name is supported on
the specified compiler.
"""
import tempfile
with tempfile.NamedTemporaryFile('w', suffix='.cpp') as f:
f.write('int main (int argc, char **argv) { return 0; }')
try:
compiler.compile([f.name], extra_postargs=[flagname])
except setuptools.distutils.errors.CompileError:
return False
return True
def cpp_flag(compiler):
"""Return the -std=c++17 compiler flag.
The newer version is prefered over c++17 (when it is available).
"""
if has_flag(compiler, '-std=c++17'): return '-std=c++17'
raise RuntimeError('Unsupported compiler -- at least C++17 support '
'is needed!')
class BuildExt(build_ext):
"""A custom build extension for adding compiler-specific options."""
c_opts = {
'msvc': ['/EHsc'],
'unix': ['-ffast-math'],
}
l_opts = {
'msvc': [],
'unix': [],
}
if sys.platform == 'darwin':
darwin_opts = ['-stdlib=libc++', '-mmacosx-version-min=10.7']
c_opts['unix'] += darwin_opts
l_opts['unix'] += darwin_opts
def build_extensions(self):
ct = self.compiler.compiler_type
opts = self.c_opts.get(ct, [])
link_opts = self.l_opts.get(ct, [])
if ct == 'unix':
opts.append('-DVERSION_INFO="%s"' % self.distribution.get_version())
opts.append(cpp_flag(self.compiler))
if has_flag(self.compiler, '-fvisibility=hidden'):
opts.append('-fvisibility=hidden')
elif ct == 'msvc':
opts.append('/DVERSION_INFO=\\"%s\\"' % self.distribution.get_version())
for ext in self.extensions:
ext.extra_compile_args = opts
ext.extra_link_args = link_opts
build_ext.build_extensions(self)
setup(
name='rapidfuzz',
version=version,
author='Max Bachmann',
author_email='contact@maxbachmann.de',
url='https://github.com/rhasspy/rapidfuzz',
description='rapid string matching library',
long_description='',
ext_modules=ext_modules,
install_requires=['pybind11>=2.4'],
setup_requires=['pybind11>=2.4'],
cmdclass={'build_ext': BuildExt},
zip_safe=False,
)