setup.py 6.71 KB
Newer Older
Minjie Wang's avatar
Minjie Wang committed
1
2
#!/usr/bin/env python
# -*- coding: utf-8 -*-
3
import glob
4
5
import os
import platform
Minjie Wang's avatar
Minjie Wang committed
6
import shutil
7
8
import sys
import sysconfig
Minjie Wang's avatar
Minjie Wang committed
9
10
11

from setuptools import find_packages
from setuptools.dist import Distribution
12
13

# need to use distutils.core for correct placement of cython dll
14
if "--inplace" in sys.argv:
15
16
17
18
19
    from distutils.core import setup
    from distutils.extension import Extension
else:
    from setuptools import setup
    from setuptools.extension import Extension
Minjie Wang's avatar
Minjie Wang committed
20

21

Minjie Wang's avatar
Minjie Wang committed
22
23
class BinaryDistribution(Distribution):
    def has_ext_modules(self):
24
        return True
Minjie Wang's avatar
Minjie Wang committed
25

26

Minjie Wang's avatar
Minjie Wang committed
27
28
CURRENT_DIR = os.path.dirname(__file__)

29

Minjie Wang's avatar
Minjie Wang committed
30
31
def get_lib_path():
    """Get library path, name and version"""
32
    # We can not import `libinfo.py` in setup.py directly since __init__.py
Minjie Wang's avatar
Minjie Wang committed
33
    # Will be invoked which introduces dependences
34
35
    libinfo_py = os.path.join(CURRENT_DIR, "./dgl/_ffi/libinfo.py")
    libinfo = {"__file__": libinfo_py}
36
    exec(
37
38
        compile(open(libinfo_py, "rb").read(), libinfo_py, "exec"),
        libinfo,
39
        libinfo,
40
41
    )
    version = libinfo["__version__"]
Gan Quan's avatar
Gan Quan committed
42

43
    lib_path = libinfo["find_lib_path"]()
Gan Quan's avatar
Gan Quan committed
44
45
    libs = [lib_path[0]]

Minjie Wang's avatar
Minjie Wang committed
46
47
    return libs, version

48

49
def get_ta_lib_pattern():
50
51
52
53
54
55
    if sys.platform.startswith("linux"):
        ta_lib_pattern = "libtensoradapter_*.so"
    elif sys.platform.startswith("darwin"):
        ta_lib_pattern = "libtensoradapter_*.dylib"
    elif sys.platform.startswith("win"):
        ta_lib_pattern = "tensoradapter_*.dll"
56
    else:
57
        raise NotImplementedError("Unsupported system: %s" % sys.platform)
58
59
    return ta_lib_pattern

60

Minjie Wang's avatar
Minjie Wang committed
61
LIBS, VERSION = get_lib_path()
62
BACKENDS = ["pytorch"]
63
64
TA_LIB_PATTERN = get_ta_lib_pattern()

65

66
67
68
69
def cleanup():
    # Wheel cleanup
    try:
        os.remove("MANIFEST.in")
70
    except BaseException:
71
72
73
74
75
76
        pass

    for path in LIBS:
        _, libname = os.path.split(path)
        try:
            os.remove(os.path.join("dgl", libname))
77
        except BaseException:
78
79
80
            pass
    for backend in BACKENDS:
        for ta_path in glob.glob(
81
            os.path.join(
82
83
84
                CURRENT_DIR, "dgl", "tensoradapter", backend, TA_LIB_PATTERN
            )
        ):
85
86
            try:
                os.remove(ta_path)
87
            except BaseException:
88
                pass
Minjie Wang's avatar
Minjie Wang committed
89

90

91
92
def config_cython():
    """Try to configure cython and return cython configuration"""
93
94
95
96
    if sys.platform.startswith("win"):
        print(
            "WARNING: Cython is not supported on Windows, will compile without cython module"
        )
97
98
99
100
        return []
    sys_cflags = sysconfig.get_config_var("CFLAGS")

    if "i386" in sys_cflags and "x86_64" in sys_cflags:
101
        print(
102
103
            "WARNING: Cython library may not be compiled correctly with both i386 and x64"
        )
104
105
106
        return []
    try:
        from Cython.Build import cythonize
107

108
109
110
111
112
113
114
        # from setuptools.extension import Extension
        if sys.version_info >= (3, 0):
            subdir = "_cy3"
        else:
            subdir = "_cy2"
        ret = []
        path = "dgl/_ffi/_cython"
115
116
        library_dirs = ["dgl", "../build/Release", "../build"]
        libraries = ["dgl"]
117
118
119
        for fn in os.listdir(path):
            if not fn.endswith(".pyx"):
                continue
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
            ret.append(
                Extension(
                    "dgl._ffi.%s.%s" % (subdir, fn[:-4]),
                    ["dgl/_ffi/_cython/%s" % fn],
                    include_dirs=[
                        "../include/",
                        "../third_party/dmlc-core/include",
                        "../third_party/dlpack/include",
                    ],
                    library_dirs=library_dirs,
                    libraries=libraries,
                    # Crashes without this flag with GCC 5.3.1
                    extra_compile_args=["-std=c++11"],
                    language="c++",
                )
            )
136
        return cythonize(ret, force=True)
137
    except ImportError:
138
139
140
        print(
            "WARNING: Cython is not installed, will compile without cython module"
        )
141
142
        return []

143

Minjie Wang's avatar
Minjie Wang committed
144
145
include_libs = False
wheel_include_libs = False
146
if "bdist_wheel" in sys.argv or os.getenv("CONDA_BUILD"):
Gan Quan's avatar
Gan Quan committed
147
    wheel_include_libs = True
148
149
elif "clean" in sys.argv:
    cleanup()
Gan Quan's avatar
Gan Quan committed
150
151
else:
    include_libs = True
Minjie Wang's avatar
Minjie Wang committed
152
153
154
155
156
157
158

setup_kwargs = {}

# For bdist_wheel only
if wheel_include_libs:
    with open("MANIFEST.in", "w") as fo:
        for path in LIBS:
159
            shutil.copy(path, os.path.join(CURRENT_DIR, "dgl"))
160
            dir_, libname = os.path.split(path)
Minjie Wang's avatar
Minjie Wang committed
161
            fo.write("include dgl/%s\n" % libname)
162
163

        for backend in BACKENDS:
164
            for ta_path in glob.glob(
165
166
                os.path.join(dir_, "tensoradapter", backend, TA_LIB_PATTERN)
            ):
167
                ta_name = os.path.basename(ta_path)
168
                os.makedirs(
169
170
171
                    os.path.join(CURRENT_DIR, "dgl", "tensoradapter", backend),
                    exist_ok=True,
                )
172
                shutil.copy(
173
174
175
                    os.path.join(dir_, "tensoradapter", backend, ta_name),
                    os.path.join(CURRENT_DIR, "dgl", "tensoradapter", backend),
                )
176
                fo.write(
177
178
                    "include dgl/tensoradapter/%s/%s\n" % (backend, ta_name)
                )
179

180
    setup_kwargs = {"include_package_data": True}
Minjie Wang's avatar
Minjie Wang committed
181
182

# For source tree setup
Gan Quan's avatar
Gan Quan committed
183
# Conda build also includes the binary library
Minjie Wang's avatar
Minjie Wang committed
184
185
if include_libs:
    rpath = [os.path.relpath(path, CURRENT_DIR) for path in LIBS]
186
    data_files = [("dgl", rpath)]
187
188
    for path in LIBS:
        for backend in BACKENDS:
189
190
191
192
193
194
195
196
197
198
199
200
201
202
            data_files.append(
                (
                    "dgl/tensoradapter/%s" % backend,
                    glob.glob(
                        os.path.join(
                            os.path.dirname(os.path.relpath(path, CURRENT_DIR)),
                            "tensoradapter",
                            backend,
                            TA_LIB_PATTERN,
                        )
                    ),
                )
            )
    setup_kwargs = {"include_package_data": True, "data_files": data_files}
Minjie Wang's avatar
Minjie Wang committed
203
204

setup(
205
    name="dgl" + os.getenv("DGL_PACKAGE_SUFFIX", ""),
Minjie Wang's avatar
Minjie Wang committed
206
    version=VERSION,
207
    description="Deep Graph Library",
Minjie Wang's avatar
Minjie Wang committed
208
    zip_safe=False,
209
210
    maintainer="DGL Team",
    maintainer_email="wmjlyjemaine@gmail.com",
Minjie Wang's avatar
Minjie Wang committed
211
    packages=find_packages(),
Minjie Wang's avatar
Minjie Wang committed
212
    install_requires=[
213
214
215
216
217
218
        "numpy>=1.14.0",
        "scipy>=1.1.0",
        "networkx>=2.1",
        "requests>=2.19.0",
        "tqdm",
        "psutil>=5.8.0",
Minjie Wang's avatar
Minjie Wang committed
219
    ],
220
    url="https://github.com/dmlc/dgl",
Minjie Wang's avatar
Minjie Wang committed
221
    distclass=BinaryDistribution,
222
    ext_modules=config_cython(),
Minjie Wang's avatar
Minjie Wang committed
223
    classifiers=[
224
225
226
        "Development Status :: 3 - Alpha",
        "Programming Language :: Python :: 3",
        "License :: OSI Approved :: Apache Software License",
Minjie Wang's avatar
Minjie Wang committed
227
    ],
228
    license="APACHE",
Minjie Wang's avatar
Minjie Wang committed
229
230
231
232
    **setup_kwargs
)

if wheel_include_libs:
233
    cleanup()