setup.py 5.02 KB
Newer Older
1
2
3
4
5
"""
Simple check list from AllenNLP repo: https://github.com/allenai/allennlp/blob/master/setup.py

To create the package for pypi.

LysandreJik's avatar
LysandreJik committed
6
1. Change the version in __init__.py, setup.py as well as docs/source/conf.py.
7
8
9
10
11
12
13
14
15

2. Commit these changes with the message: "Release: VERSION"

3. Add a tag in git to mark the release: "git tag VERSION -m'Adds tag VERSION for pypi' "
   Push the tag to git: git push --tags origin master

4. Build both the sources and the wheel. Do not change anything in setup.py between
   creating the wheel and the source distribution (obviously).

thomwolf's avatar
thomwolf committed
16
   For the wheel, run: "python setup.py bdist_wheel" in the top level directory.
17
   (this will build a wheel for the python version you use to build it).
18
19

   For the sources, run: "python setup.py sdist"
thomwolf's avatar
thomwolf committed
20
   You should now have a /dist directory with both .whl and .tar.gz source versions.
21
22
23
24
25

5. Check that everything looks correct by uploading the package to the pypi test server:

   twine upload dist/* -r pypitest
   (pypi suggest using twine as other methods upload files via plaintext.)
Lysandre's avatar
Lysandre committed
26
27
   You may have to specify the repository url, use the following command then:
   twine upload dist/* -r pypitest --repository-url=https://test.pypi.org/legacy/
28
29

   Check that you can install it in a virtualenv by running:
30
   pip install -i https://testpypi.python.org/pypi transformers
31
32
33
34
35
36

6. Upload the final version to actual pypi:
   twine upload dist/* -r pypi

7. Copy the release notes from RELEASE.md to the tag in github once everything is looking hunky-dory.

37
38
39
8. Update the documentation commit in .circleci/deploy.sh for the accurate documentation to be displayed

9. Update README.md to redirect to correct documentation.
40
"""
Aymeric Augustin's avatar
Aymeric Augustin committed
41

42
43
44
import shutil
from pathlib import Path

thomwolf's avatar
thomwolf committed
45
46
from setuptools import find_packages, setup

47

48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# Remove stale transformers.egg-info directory to avoid https://github.com/pypa/pip/issues/5466
stale_egg_info = Path(__file__).parent / "transformers.egg-info"
if stale_egg_info.exists():
    print(
        (
            "Warning: {} exists.\n\n"
            "If you recently updated transformers to 3.0 or later, this is expected,\n"
            "but it may prevent transformers from installing in editable mode.\n\n"
            "This directory is automatically generated by Python's packaging tools.\n"
            "I will remove it now.\n\n"
            "See https://github.com/pypa/pip/issues/5466 for details.\n"
        ).format(stale_egg_info)
    )
    shutil.rmtree(stale_egg_info)


64
65
66
extras = {}

extras["mecab"] = ["mecab-python3"]
67
extras["sklearn"] = ["scikit-learn"]
68
extras["tf"] = ["tensorflow"]
69
extras["tf-cpu"] = ["tensorflow-cpu"]
70
extras["torch"] = ["torch==1.4.0"]
71

72
extras["serving"] = ["pydantic", "uvicorn", "fastapi", "starlette"]
73
74
75
76
extras["all"] = extras["serving"] + ["tensorflow", "torch"]

extras["testing"] = ["pytest", "pytest-xdist"]
extras["docs"] = ["recommonmark", "sphinx", "sphinx-markdown-tables", "sphinx-rtd-theme"]
77
78
extras["quality"] = [
    "black",
LysandreJik's avatar
LysandreJik committed
79
    "isort @ git+git://github.com/timothycrosley/isort.git@e63ae06ec7d70b06df9e528357650281a3d3ec22#egg=isort",
80
81
    "flake8",
]
82
extras["dev"] = extras["testing"] + extras["quality"] + ["mecab-python3", "scikit-learn", "tensorflow", "torch"]
83

thomwolf's avatar
thomwolf committed
84
setup(
85
    name="transformers",
LysandreJik's avatar
LysandreJik committed
86
    version="2.8.0",
Lysandre's avatar
Lysandre committed
87
    author="Thomas Wolf, Lysandre Debut, Victor Sanh, Julien Chaumond, Sam Shleifer, Google AI Language Team Authors, Open AI team Authors, Facebook AI Authors, Carnegie Mellon University Authors",
thomwolf's avatar
thomwolf committed
88
    author_email="thomas@huggingface.co",
thomwolf's avatar
thomwolf committed
89
    description="State-of-the-art Natural Language Processing for TensorFlow 2.0 and PyTorch",
90
    long_description=open("README.md", "r", encoding="utf-8").read(),
thomwolf's avatar
thomwolf committed
91
    long_description_content_type="text/markdown",
92
93
    keywords="NLP deep learning transformer pytorch tensorflow BERT GPT GPT-2 google openai CMU",
    license="Apache",
94
    url="https://github.com/huggingface/transformers",
Aymeric Augustin's avatar
Aymeric Augustin committed
95
    package_dir={"": "src"},
96
    packages=find_packages("src"),
97
98
    install_requires=[
        "numpy",
99
        "tokenizers == 0.7.0",
100
101
        # dataclasses for Python versions that don't have it
        "dataclasses;python_version<'3.7'",
Aymeric Augustin's avatar
Aymeric Augustin committed
102
        # filesystem locks e.g. to prevent parallel downloads
103
        "filelock",
Aymeric Augustin's avatar
Aymeric Augustin committed
104
        # for downloading models over HTTPS
105
        "requests",
Aymeric Augustin's avatar
Aymeric Augustin committed
106
        # progress bars in model download and training scripts
107
        "tqdm >= 4.27",
Aymeric Augustin's avatar
Aymeric Augustin committed
108
        # for OpenAI GPT
109
        "regex != 2019.12.17",
Aymeric Augustin's avatar
Aymeric Augustin committed
110
        # for XLNet
111
        "sentencepiece",
Aymeric Augustin's avatar
Aymeric Augustin committed
112
        # for XLM
113
        "sacremoses",
thomwolf's avatar
thomwolf committed
114
    ],
115
116
    extras_require=extras,
    scripts=["transformers-cli"],
117
    python_requires=">=3.6.0",
thomwolf's avatar
thomwolf committed
118
    classifiers=[
Aymeric Augustin's avatar
Aymeric Augustin committed
119
120
121
        "Development Status :: 5 - Production/Stable",
        "Intended Audience :: Developers",
        "Intended Audience :: Education",
122
123
        "Intended Audience :: Science/Research",
        "License :: OSI Approved :: Apache Software License",
Aymeric Augustin's avatar
Aymeric Augustin committed
124
        "Operating System :: OS Independent",
125
        "Programming Language :: Python :: 3",
Aymeric Augustin's avatar
Aymeric Augustin committed
126
127
        "Programming Language :: Python :: 3.6",
        "Programming Language :: Python :: 3.7",
128
        "Topic :: Scientific/Engineering :: Artificial Intelligence",
thomwolf's avatar
thomwolf committed
129
130
    ],
)