forked from NVIDIA-Merlin/NVTabular
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetup.py
113 lines (98 loc) · 3.99 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#
# Copyright (c) 2021, NVIDIA CORPORATION.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
import os
import subprocess
import sys
from distutils.spawn import find_executable
from pybind11.setup_helpers import Pybind11Extension
from pybind11.setup_helpers import build_ext as build_pybind11
from setuptools import find_packages, setup
try:
import versioneer
except ImportError:
# we have a versioneer.py file living in the same directory as this file, but
# if we're using pep 517/518 to build from pyproject.toml its not going to find it
# https://github.com/python-versioneer/python-versioneer/issues/193#issue-408237852
# make this work by adding this directory to the python path
sys.path.append(os.path.dirname(os.path.realpath(__file__)))
import versioneer
class build_pybind_and_proto(build_pybind11):
def run(self):
build_pybind11.run(self)
protoc = None
if "PROTOC" in os.environ and os.path.exists(os.environ["PROTOC"]):
protoc = os.environ["PROTOC"]
else:
protoc = find_executable("protoc")
if protoc is None:
sys.stderr.write("protoc not found")
sys.exit(1)
# need to set this environment variable otherwise we get an error like "
# model_config.proto: A file with this name is already in the pool. " when
# importing the generated file
env = os.environ.copy()
env["PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION"] = "python"
for source in ["nvtabular/inference/triton/model_config.proto"]:
output = source.replace(".proto", "_pb2.py")
pwd = os.path.dirname(output)
if not os.path.exists(output) or (os.path.getmtime(source) > os.path.getmtime(output)):
print("Generating", output, "from", source)
cmd = [protoc, f"--python_out={pwd}", f"--proto_path={pwd}", source]
subprocess.check_call(cmd, env=env)
else:
print("not regenerating", output, " - file exists and proto hasn't been updated")
ext_modules = [
Pybind11Extension(
"nvtabular_cpp",
[
"cpp/nvtabular/__init__.cc",
"cpp/nvtabular/inference/__init__.cc",
"cpp/nvtabular/inference/categorify.cc",
"cpp/nvtabular/inference/fill.cc",
],
define_macros=[("VERSION_INFO", versioneer.get_version())],
include_dirs=["./cpp/"],
),
]
cmdclass = versioneer.get_cmdclass()
cmdclass["build_ext"] = build_pybind_and_proto
def parse_requirements(filename):
"""load requirements from a pip requirements file"""
lineiter = (line.strip() for line in open(filename))
return [line for line in lineiter if line and not line.startswith("#")]
install_reqs = parse_requirements("./requirements.txt")
setup(
name="nvtabular",
version=versioneer.get_version(),
packages=find_packages(),
url="https://github.com/NVIDIA/NVTabular",
author="NVIDIA Corporation",
license="Apache 2.0",
long_description=open("README.md", encoding="utf8").read(),
long_description_content_type="text/markdown",
classifiers=[
"Development Status :: 4 - Beta",
"Programming Language :: Python :: 3",
"Intended Audience :: Developers",
"License :: OSI Approved :: Apache Software License",
"Topic :: Software Development :: Libraries",
"Topic :: Scientific/Engineering",
],
cmdclass=cmdclass,
ext_modules=ext_modules,
zip_safe=False,
install_requires=install_reqs,
)