"git@developer.sourcefind.cn:renzhc/diffusers_dcu.git" did not exist on "cee3aa0dd40eaab8e84ab947a5c896efc150428b"
setup.py 7.01 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

peizhou001's avatar
peizhou001 committed
49
def get_lib_pattern(lib_name):
50
    if sys.platform.startswith("linux"):
peizhou001's avatar
peizhou001 committed
51
        lib_pattern = f"lib{lib_name}_*.so"
52
    elif sys.platform.startswith("darwin"):
peizhou001's avatar
peizhou001 committed
53
        lib_pattern = f"lib{lib_name}_*.dylib"
54
    elif sys.platform.startswith("win"):
peizhou001's avatar
peizhou001 committed
55
        lib_pattern = f"{lib_name}_*.dll"
56
    else:
57
        raise NotImplementedError("Unsupported system: %s" % sys.platform)
peizhou001's avatar
peizhou001 committed
58
    return lib_pattern
59
60


Minjie Wang's avatar
Minjie Wang committed
61
LIBS, VERSION = get_lib_path()
62
BACKENDS = ["pytorch"]
peizhou001's avatar
peizhou001 committed
63
64
65
66
67
68
69
70
71
72


def remove_lib(lib_name):
    for lib_path in glob.glob(
        os.path.join(CURRENT_DIR, "dgl", lib_name, get_lib_pattern(lib_name))
    ):
        try:
            os.remove(lib_path)
        except BaseException:
            pass
73

74

75
76
77
78
def cleanup():
    # Wheel cleanup
    try:
        os.remove("MANIFEST.in")
79
    except BaseException:
80
81
82
83
84
85
        pass

    for path in LIBS:
        _, libname = os.path.split(path)
        try:
            os.remove(os.path.join("dgl", libname))
86
        except BaseException:
87
88
            pass
    for backend in BACKENDS:
peizhou001's avatar
peizhou001 committed
89
        remove_lib("tensoradapter")
Minjie Wang's avatar
Minjie Wang committed
90

91
        if backend == "pytorch":
peizhou001's avatar
peizhou001 committed
92
93
            remove_lib("dgl_sparse")
            remove_lib("graphbolt")
94

95

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

    if "i386" in sys_cflags and "x86_64" in sys_cflags:
106
        print(
107
108
            "WARNING: Cython library may not be compiled correctly with both i386 and x64"
        )
109
110
111
        return []
    try:
        from Cython.Build import cythonize
112

113
114
115
116
117
118
119
        # from setuptools.extension import Extension
        if sys.version_info >= (3, 0):
            subdir = "_cy3"
        else:
            subdir = "_cy2"
        ret = []
        path = "dgl/_ffi/_cython"
120
121
        library_dirs = ["dgl", "../build/Release", "../build"]
        libraries = ["dgl"]
122
123
124
        for fn in os.listdir(path):
            if not fn.endswith(".pyx"):
                continue
125
126
127
128
129
130
131
132
133
134
135
136
            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
137
                    extra_compile_args=["-std=c++14"],
138
139
140
                    language="c++",
                )
            )
141
        return cythonize(ret, force=True)
142
    except ImportError:
143
144
145
        print(
            "WARNING: Cython is not installed, will compile without cython module"
        )
146
147
        return []

148

peizhou001's avatar
peizhou001 committed
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
def copy_lib(lib_name, backend=""):
    for lib_path in glob.glob(
        os.path.join(dir_, lib_name, backend, get_lib_pattern(lib_name))
    ):
        lib_file_name = os.path.basename(lib_path)
        dst_dir_ = os.path.dirname(
            os.path.join(CURRENT_DIR, "dgl", lib_name, backend)
        )
        os.makedirs(
            dst_dir_,
            exist_ok=True,
        )
        shutil.copy(
            os.path.join(dir_, lib_name, backend, lib_file_name),
            dst_dir_,
        )
        fo.write("include dgl/tensoradapter/%s/%s\n" % (backend, lib_file_name))


Minjie Wang's avatar
Minjie Wang committed
168
169
include_libs = False
wheel_include_libs = False
170
if "bdist_wheel" in sys.argv or os.getenv("CONDA_BUILD"):
Gan Quan's avatar
Gan Quan committed
171
    wheel_include_libs = True
172
173
elif "clean" in sys.argv:
    cleanup()
Gan Quan's avatar
Gan Quan committed
174
175
else:
    include_libs = True
Minjie Wang's avatar
Minjie Wang committed
176
177
178
179
180
181
182

setup_kwargs = {}

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

        for backend in BACKENDS:
peizhou001's avatar
peizhou001 committed
188
            copy_lib("tensoradapter", backend)
189
            if backend == "pytorch":
peizhou001's avatar
peizhou001 committed
190
191
                copy_lib("dgl_sparse")
                copy_lib("graphbolt")
192
    setup_kwargs = {"include_package_data": True}
Minjie Wang's avatar
Minjie Wang committed
193

peizhou001's avatar
peizhou001 committed
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208

def get_lib_file_path(lib_name, backend=""):
    return (
        f"dgl/{lib_name}" if backend == "" else f"dgl/{lib_name}/{backend}",
        glob.glob(
            os.path.join(
                os.path.dirname(os.path.relpath(path, CURRENT_DIR)),
                lib_name,
                backend,
                get_lib_pattern(lib_name),
            )
        ),
    )


Minjie Wang's avatar
Minjie Wang committed
209
# For source tree setup
Gan Quan's avatar
Gan Quan committed
210
# Conda build also includes the binary library
Minjie Wang's avatar
Minjie Wang committed
211
212
if include_libs:
    rpath = [os.path.relpath(path, CURRENT_DIR) for path in LIBS]
213
    data_files = [("dgl", rpath)]
214
215
    for path in LIBS:
        for backend in BACKENDS:
peizhou001's avatar
peizhou001 committed
216
            data_files.append(get_lib_file_path("tensoradapter", backend))
217
            if backend == "pytorch":
peizhou001's avatar
peizhou001 committed
218
219
                data_files.append(get_lib_file_path("dgl_sparse"))
                data_files.append(get_lib_file_path("graphbolt"))
220
    setup_kwargs = {"include_package_data": True, "data_files": data_files}
Minjie Wang's avatar
Minjie Wang committed
221
222

setup(
223
    name="dgl" + os.getenv("DGL_PACKAGE_SUFFIX", ""),
Minjie Wang's avatar
Minjie Wang committed
224
    version=VERSION,
225
    description="Deep Graph Library",
Minjie Wang's avatar
Minjie Wang committed
226
    zip_safe=False,
227
228
    maintainer="DGL Team",
    maintainer_email="wmjlyjemaine@gmail.com",
Minjie Wang's avatar
Minjie Wang committed
229
    packages=find_packages(),
Minjie Wang's avatar
Minjie Wang committed
230
    install_requires=[
231
232
233
234
235
236
        "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
237
    ],
238
    url="https://github.com/dmlc/dgl",
Minjie Wang's avatar
Minjie Wang committed
239
    distclass=BinaryDistribution,
240
    ext_modules=config_cython(),
Minjie Wang's avatar
Minjie Wang committed
241
    classifiers=[
242
243
244
        "Development Status :: 3 - Alpha",
        "Programming Language :: Python :: 3",
        "License :: OSI Approved :: Apache Software License",
Minjie Wang's avatar
Minjie Wang committed
245
    ],
246
    license="APACHE",
peizhou001's avatar
peizhou001 committed
247
    **setup_kwargs,
Minjie Wang's avatar
Minjie Wang committed
248
249
250
)

if wheel_include_libs:
251
    cleanup()