forked from NVIDIA-Merlin/NVTabular
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
78 lines (67 loc) · 2.66 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
#
# 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 setuptools import find_packages, setup
from setuptools.command.build_ext import build_ext
import versioneer
class build_proto(build_ext):
def 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)
# Run original build_ext command
build_ext.run(self)
cmdclass = versioneer.get_cmdclass()
cmdclass["build_ext"] = build_proto
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,
)