From d530bf6b4b59dbec228ee32af08f4da829dfbd82 Mon Sep 17 00:00:00 2001 From: Josh Fromm Date: Mon, 29 Jul 2019 16:12:52 -0700 Subject: [PATCH 1/2] Fixed topi bdist_wheel build to include libraries. --- topi/python/setup.py | 57 +++++++++++++++++++++++++++++++++++++++----- 1 file changed, 51 insertions(+), 6 deletions(-) diff --git a/topi/python/setup.py b/topi/python/setup.py index bff0576705dc..f201b5f44afd 100644 --- a/topi/python/setup.py +++ b/topi/python/setup.py @@ -18,8 +18,11 @@ # pylint: disable=invalid-name, exec-used """Setup TOPI package.""" from __future__ import absolute_import -import sys import os +import shutil +import sys +import sysconfig +import platform from setuptools import find_packages from setuptools.dist import Distribution @@ -31,6 +34,9 @@ from setuptools import setup from setuptools.extension import Extension +CURRENT_DIR = os.path.dirname(__file__) + + def get_lib_names(): if sys.platform.startswith('win32'): return ['libtvm_topi.dll', 'tvm_topi.dll'] @@ -38,14 +44,15 @@ def get_lib_names(): return ['libtvm_topi.dylib', 'tvm_topi.dylib'] return ['libtvm_topi.so', 'tvm_topi.so'] + def get_lib_path(): """Get library path, name and version""" # We can not import `libinfo.py` in setup.py directly since __init__.py # Will be invoked which introduces dependences - CURRENT_DIR = os.path.dirname(__file__) libinfo_py = os.path.join(CURRENT_DIR, '../../python/tvm/_ffi/libinfo.py') libinfo = {'__file__': libinfo_py} - exec(compile(open(libinfo_py, "rb").read(), libinfo_py, 'exec'), libinfo, libinfo) + exec(compile(open(libinfo_py, "rb").read(), + libinfo_py, 'exec'), libinfo, libinfo) version = libinfo['__version__'] if not os.getenv('CONDA_BUILD'): lib_path = libinfo['find_lib_path'](get_lib_names()) @@ -59,6 +66,7 @@ def get_lib_path(): libs = None return libs, version + LIB_LIST, __version__ = get_lib_path() if not os.getenv('CONDA_BUILD'): @@ -72,13 +80,50 @@ def get_lib_path(): else: setup_kwargs = {} + +include_libs = False +wheel_include_libs = False +if not os.getenv('CONDA_BUILD'): + if "bdist_wheel" in sys.argv: + wheel_include_libs = True + else: + include_libs = True + +# For bdist_wheel only +if wheel_include_libs: + with open("MANIFEST.in", "w") as fo: + for path in LIB_LIST: + shutil.copy(path, os.path.join(CURRENT_DIR, 'topi')) + _, libname = os.path.split(path) + fo.write("include topi/%s\n" % libname) + setup_kwargs = { + "include_package_data": True + } + +if include_libs: + curr_path = os.path.dirname(os.path.abspath(os.path.expanduser(__file__))) + for i, path in enumerate(LIB_LIST): + LIB_LIST[i] = os.path.relpath(path, curr_path) + setup_kwargs = { + "include_package_data": True, + "data_files": [('topi', LIB_LIST)] + } + setup(name='topi', version=__version__, description="TOPI: TVM operator index", install_requires=[ - "numpy", - "decorator", - ], + "numpy", + "decorator", + ], packages=find_packages(), url='https://github.com/dmlc/tvm', **setup_kwargs) + + +if wheel_include_libs: + # Wheel cleanup + os.remove("MANIFEST.in") + for path in LIB_LIST: + _, libname = os.path.split(path) + os.remove("topi/%s" % libname) From fc64704b7e5846d8327eef2b6d3eb7ca471f14e6 Mon Sep 17 00:00:00 2001 From: Josh Fromm Date: Mon, 29 Jul 2019 16:18:35 -0700 Subject: [PATCH 2/2] Removed unneeded imports --- topi/python/setup.py | 2 -- 1 file changed, 2 deletions(-) diff --git a/topi/python/setup.py b/topi/python/setup.py index f201b5f44afd..f43e22e5ccf6 100644 --- a/topi/python/setup.py +++ b/topi/python/setup.py @@ -21,8 +21,6 @@ import os import shutil import sys -import sysconfig -import platform from setuptools import find_packages from setuptools.dist import Distribution