Commit 4ce93200 by Josh Fromm Committed by Tianqi Chen

[TOPI] Enable standalone wheel build (#3657)

* Fixed topi bdist_wheel build to include libraries.

* Removed unneeded imports
parent 9d583cf5
...@@ -18,8 +18,9 @@ ...@@ -18,8 +18,9 @@
# pylint: disable=invalid-name, exec-used # pylint: disable=invalid-name, exec-used
"""Setup TOPI package.""" """Setup TOPI package."""
from __future__ import absolute_import from __future__ import absolute_import
import sys
import os import os
import shutil
import sys
from setuptools import find_packages from setuptools import find_packages
from setuptools.dist import Distribution from setuptools.dist import Distribution
...@@ -31,6 +32,9 @@ else: ...@@ -31,6 +32,9 @@ else:
from setuptools import setup from setuptools import setup
from setuptools.extension import Extension from setuptools.extension import Extension
CURRENT_DIR = os.path.dirname(__file__)
def get_lib_names(): def get_lib_names():
if sys.platform.startswith('win32'): if sys.platform.startswith('win32'):
return ['libtvm_topi.dll', 'tvm_topi.dll'] return ['libtvm_topi.dll', 'tvm_topi.dll']
...@@ -38,14 +42,15 @@ def get_lib_names(): ...@@ -38,14 +42,15 @@ def get_lib_names():
return ['libtvm_topi.dylib', 'tvm_topi.dylib'] return ['libtvm_topi.dylib', 'tvm_topi.dylib']
return ['libtvm_topi.so', 'tvm_topi.so'] return ['libtvm_topi.so', 'tvm_topi.so']
def get_lib_path(): def get_lib_path():
"""Get library path, name and version""" """Get library path, name and version"""
# We can not import `libinfo.py` in setup.py directly since __init__.py # We can not import `libinfo.py` in setup.py directly since __init__.py
# Will be invoked which introduces dependences # 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_py = os.path.join(CURRENT_DIR, '../../python/tvm/_ffi/libinfo.py')
libinfo = {'__file__': 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__'] version = libinfo['__version__']
if not os.getenv('CONDA_BUILD'): if not os.getenv('CONDA_BUILD'):
lib_path = libinfo['find_lib_path'](get_lib_names()) lib_path = libinfo['find_lib_path'](get_lib_names())
...@@ -59,6 +64,7 @@ def get_lib_path(): ...@@ -59,6 +64,7 @@ def get_lib_path():
libs = None libs = None
return libs, version return libs, version
LIB_LIST, __version__ = get_lib_path() LIB_LIST, __version__ = get_lib_path()
if not os.getenv('CONDA_BUILD'): if not os.getenv('CONDA_BUILD'):
...@@ -72,6 +78,35 @@ if not os.getenv('CONDA_BUILD'): ...@@ -72,6 +78,35 @@ if not os.getenv('CONDA_BUILD'):
else: else:
setup_kwargs = {} 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', setup(name='topi',
version=__version__, version=__version__,
description="TOPI: TVM operator index", description="TOPI: TVM operator index",
...@@ -82,3 +117,11 @@ setup(name='topi', ...@@ -82,3 +117,11 @@ setup(name='topi',
packages=find_packages(), packages=find_packages(),
url='https://github.com/dmlc/tvm', url='https://github.com/dmlc/tvm',
**setup_kwargs) **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)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment