setup.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. from __future__ import print_function
  2. import distutils.spawn
  3. import os
  4. import re
  5. import shlex
  6. import subprocess
  7. import sys
  8. from setuptools import find_packages
  9. from setuptools import setup
  10. def get_version():
  11. filename = "labelme/__init__.py"
  12. with open(filename) as f:
  13. match = re.search(
  14. r"""^__version__ = ['"]([^'"]*)['"]""", f.read(), re.M
  15. )
  16. if not match:
  17. raise RuntimeError("{} doesn't contain __version__".format(filename))
  18. version = match.groups()[0]
  19. return version
  20. def get_install_requires():
  21. PY3 = sys.version_info[0] == 3
  22. PY2 = sys.version_info[0] == 2
  23. assert PY3 or PY2
  24. install_requires = [
  25. "imgviz>=0.11",
  26. "matplotlib<3.3", # for PyInstaller
  27. "numpy",
  28. "Pillow>=2.8",
  29. "PyYAML",
  30. "qtpy!=1.11.2",
  31. "termcolor",
  32. ]
  33. # Find python binding for qt with priority:
  34. # PyQt5 -> PySide2 -> PyQt4,
  35. # and PyQt5 is automatically installed on Python3.
  36. QT_BINDING = None
  37. try:
  38. import PyQt5 # NOQA
  39. QT_BINDING = "pyqt5"
  40. except ImportError:
  41. pass
  42. if QT_BINDING is None:
  43. try:
  44. import PySide2 # NOQA
  45. QT_BINDING = "pyside2"
  46. except ImportError:
  47. pass
  48. if QT_BINDING is None:
  49. try:
  50. import PyQt4 # NOQA
  51. QT_BINDING = "pyqt4"
  52. except ImportError:
  53. if PY2:
  54. print(
  55. "Please install PyQt5, PySide2 or PyQt4 for Python2.\n"
  56. "Note that PyQt5 can be installed via pip for Python3.",
  57. file=sys.stderr,
  58. )
  59. sys.exit(1)
  60. assert PY3
  61. # PyQt5 can be installed via pip for Python3
  62. # 5.15.3, 5.15.4 won't work with PyInstaller
  63. install_requires.append("PyQt5!=5.15.3,!=5.15.4")
  64. QT_BINDING = "pyqt5"
  65. del QT_BINDING
  66. if os.name == "nt": # Windows
  67. install_requires.append("colorama")
  68. return install_requires
  69. def get_long_description():
  70. with open("README.md") as f:
  71. long_description = f.read()
  72. try:
  73. import github2pypi
  74. return github2pypi.replace_url(
  75. slug="wkentaro/labelme", content=long_description
  76. )
  77. except Exception:
  78. return long_description
  79. def main():
  80. version = get_version()
  81. if sys.argv[1] == "release":
  82. if not distutils.spawn.find_executable("twine"):
  83. print(
  84. "Please install twine:\n\n\tpip install twine\n",
  85. file=sys.stderr,
  86. )
  87. sys.exit(1)
  88. commands = [
  89. "python tests/docs_tests/man_tests/test_labelme_1.py",
  90. "git push origin main",
  91. "git tag v{:s}".format(version),
  92. "git push origin --tags",
  93. "python setup.py sdist",
  94. "twine upload dist/labelme-{:s}.tar.gz".format(version),
  95. ]
  96. for cmd in commands:
  97. print("+ {:s}".format(cmd))
  98. subprocess.check_call(shlex.split(cmd))
  99. sys.exit(0)
  100. setup(
  101. name="labelme",
  102. version=version,
  103. packages=find_packages(exclude=["github2pypi"]),
  104. description="Image Polygonal Annotation with Python",
  105. long_description=get_long_description(),
  106. long_description_content_type="text/markdown",
  107. author="Kentaro Wada",
  108. author_email="www.kentaro.wada@gmail.com",
  109. url="https://github.com/wkentaro/labelme",
  110. install_requires=get_install_requires(),
  111. license="GPLv3",
  112. keywords="Image Annotation, Machine Learning",
  113. classifiers=[
  114. "Development Status :: 5 - Production/Stable",
  115. "Intended Audience :: Developers",
  116. "Natural Language :: English",
  117. "Programming Language :: Python",
  118. "Programming Language :: Python :: 2.7",
  119. "Programming Language :: Python :: 3.5",
  120. "Programming Language :: Python :: 3.6",
  121. "Programming Language :: Python :: 3.7",
  122. "Programming Language :: Python :: Implementation :: CPython",
  123. "Programming Language :: Python :: Implementation :: PyPy",
  124. ],
  125. package_data={"labelme": ["icons/*", "config/*.yaml"]},
  126. entry_points={
  127. "console_scripts": [
  128. "labelme=labelme.__main__:main",
  129. "labelme_draw_json=labelme.cli.draw_json:main",
  130. "labelme_draw_label_png=labelme.cli.draw_label_png:main",
  131. "labelme_json_to_dataset=labelme.cli.json_to_dataset:main",
  132. "labelme_on_docker=labelme.cli.on_docker:main",
  133. ],
  134. },
  135. data_files=[("share/man/man1", ["docs/man/labelme.1"])],
  136. )
  137. if __name__ == "__main__":
  138. main()