forked from kumpera/distcp-playground
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
81 lines (66 loc) · 2.27 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# Copyright (c) Meta Platforms, Inc. and affiliates
import distutils.command.clean
import glob
import os
import shutil
import subprocess
from typing import Dict, Union, List
from setuptools import setup, find_namespace_packages
# Package name
package_name = "distcp_playground"
# Version information
cwd: str = os.path.dirname(os.path.abspath(__file__))
version_txt: str = os.path.join(cwd, "version.txt")
with open(version_txt, "r") as f:
version: str = f.readline().strip()
try:
sha: str = (
subprocess.check_output(["git", "rev-parse", "HEAD"], cwd=cwd)
.decode("ascii")
.strip()
)
except Exception:
sha = "Unknown"
if os.getenv("BUILD_VERSION"):
version = os.getenv("BUILD_VERSION", version)
elif sha != "Unknown":
version += "+" + sha[:7]
def write_version_file() -> None:
version_path = os.path.join(cwd, "distcp_playground", "version.py")
with open(version_path, "w") as f:
f.write("__version__ = '{}'\n".format(version))
f.write("git_version = {}\n".format(repr(sha)))
# Package requirements
requirements = [
# This represents a nightly version of PyTorch.
# It can be installed as a binary or from source.
"torch>=1.12.0.dev"
]
class clean(distutils.command.clean.clean): # type: ignore
def run(self) -> None:
with open(".gitignore", "r") as f:
ignores = f.read()
for wildcard in filter(None, ignores.split("\n")):
for filename in glob.glob(wildcard):
try:
os.remove(filename)
except OSError:
shutil.rmtree(filename, ignore_errors=True)
# It's an old-style class in Python 2.7...
distutils.command.clean.clean.run(self) # type: ignore
if __name__ == "__main__":
write_version_file()
setup(
# Metadata
name=package_name,
version=version,
author="Rodrigo Kumpera",
url="https://https://github.com/kumpera/distcp-playground",
description="PyTorch Distributed checkpoint random basket of prototypes",
license="MIT",
# Package info
packages=find_namespace_packages(),
install_requires=requirements,
# extras_require=extras,
cmdclass={"clean": clean},
)