setup.py 4.02 KB
Newer Older
Soumith Chintala's avatar
Soumith Chintala committed
1
#!/usr/bin/env python
2
3
import os
import platform
4
import subprocess
Soumith Chintala's avatar
Soumith Chintala committed
5
6

from setuptools import setup, find_packages
7
from torch.utils.cpp_extension import BuildExtension, CppExtension
Soumith Chintala's avatar
Soumith Chintala committed
8

9
10
11
12
13

def check_env_flag(name, default=''):
    return os.getenv(name, default).upper() in set(['ON', '1', 'YES', 'TRUE', 'Y'])

DEBUG = check_env_flag('DEBUG')
14
15
16
17
18
IS_WHEEL = check_env_flag('IS_WHEEL')
IS_CONDA = check_env_flag('IS_CONDA')

print('DEBUG:', DEBUG, 'IS_WHEEL:', IS_WHEEL, 'IS_CONDA:', IS_CONDA)

19
20
21
22
23
24
25
26
27
eca = []
ela = []
if DEBUG:
    if platform.system() == 'Windows':
        ela += ['/DEBUG:FULL']
    else:
        eca += ['-O0', '-g']
        ela += ['-O0', '-g']

28
29
30
31
32

libraries = []
include_dirs = []
extra_objects = []

33
34
35
36
# Hypothetically, the conda distribution could rely on an external sox,
# but the library is pretty small and it is not available on the default
# anaconda channel.  So we statically link it in, just as we do with wheels.
if IS_WHEEL or IS_CONDA:
37
38
39
40
41
    audio_path = os.path.dirname(os.path.abspath(__file__))

    include_dirs += [os.path.join(audio_path, 'third_party/flac/include')]
    include_dirs += [os.path.join(audio_path, 'third_party/lame/include')]
    include_dirs += [os.path.join(audio_path, 'third_party/sox/include')]
42
    include_dirs += [os.path.join(audio_path, 'third_party/mad/include')]
43

44
45
46
    # proper link order (sox, mad, flac, lame)
    # (the most important thing is that dependencies come after a libraryl
    # e.g., sox comes first)
47
    extra_objects += [os.path.join(audio_path, 'third_party/sox/lib/libsox.a')]
48
    extra_objects += [os.path.join(audio_path, 'third_party/mad/lib/libmad.a')]
49
50
51
52
53
54
55
56
    extra_objects += [os.path.join(audio_path, 'third_party/flac/lib/libFLAC.a')]
    extra_objects += [os.path.join(audio_path, 'third_party/lame/lib/libmp3lame.a')]
else:
    libraries += ['sox']


# Creating the version file
cwd = os.path.dirname(os.path.abspath(__file__))
moto's avatar
moto committed
57
version = '0.6.0a0'
58
59
60
61
62
63
64
sha = 'Unknown'

try:
    sha = subprocess.check_output(['git', 'rev-parse', 'HEAD'], cwd=cwd).decode('ascii').strip()
except Exception:
    pass

65
66
if os.getenv('BUILD_VERSION'):
    version = os.getenv('BUILD_VERSION')
67
68
69
70
71
72
73
74
75
elif sha != 'Unknown':
    version += '+' + sha[:7]
print('-- Building version ' + version)

version_path = os.path.join(cwd, 'torchaudio', 'version.py')
with open(version_path, 'w') as f:
    f.write("__version__ = '{}'\n".format(version))
    f.write("git_version = {}\n".format(repr(sha)))

76
pytorch_package_version = os.getenv('PYTORCH_VERSION')
77

78
pytorch_package_dep = 'torch'
79
80
if pytorch_package_version is not None:
    pytorch_package_dep += "==" + pytorch_package_version
81

peterjc123's avatar
peterjc123 committed
82
83
84
85
86
if platform.system() == 'Windows':
    ext_modules = None
else:
    ext_modules = [
        CppExtension(
87
88
            'torchaudio._torchaudio',
            ['torchaudio/csrc/sox.cpp'],
peterjc123's avatar
peterjc123 committed
89
            libraries=libraries,
90
            include_dirs=include_dirs + [cwd],
peterjc123's avatar
peterjc123 committed
91
92
93
94
95
            extra_compile_args=eca,
            extra_objects=extra_objects,
            extra_link_args=ela),
    ]

96

Soumith Chintala's avatar
Soumith Chintala committed
97
setup(
98
    name="torchaudio",
99
    version=version,
Soumith Chintala's avatar
Soumith Chintala committed
100
101
    description="An audio package for PyTorch",
    url="https://github.com/pytorch/audio",
102
    author="Soumith Chintala, David Pollack, Sean Naren, Peter Goldsborough",
Soumith Chintala's avatar
Soumith Chintala committed
103
    author_email="soumith@pytorch.org",
Hong Xu's avatar
Hong Xu committed
104
105
106
107
108
109
110
111
112
    classifiers=[
        "Environment :: Plugins",
        "Intended Audience :: Developers",
        "Intended Audience :: Science/Research",
        "License :: OSI Approved :: BSD License",
        "Operating System :: MacOS :: MacOS X",
        "Operating System :: Microsoft :: Windows",
        "Operating System :: POSIX",
        "Programming Language :: C++",
113
114
        "Programming Language :: Python :: 2.7",
        "Programming Language :: Python :: 3",
Hong Xu's avatar
Hong Xu committed
115
116
117
118
        "Programming Language :: Python :: Implementation :: CPython",
        "Topic :: Multimedia :: Sound/Audio",
        "Topic :: Scientific/Engineering :: Artificial Intelligence"
    ],
119
    packages=find_packages(exclude=["build*", "test*", "torchaudio.csrc*"]),
peterjc123's avatar
peterjc123 committed
120
    ext_modules=ext_modules,
121
    cmdclass={'build_ext': BuildExtension},
122
    install_requires=[pytorch_package_dep]
123
)