setup.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. from __future__ import print_function
  2. import distutils.spawn
  3. import os.path
  4. import re
  5. from setuptools import find_packages
  6. from setuptools import setup
  7. import shlex
  8. import subprocess
  9. import sys
  10. import github2pypi
  11. PY3 = sys.version_info[0] == 3
  12. PY2 = sys.version_info[0] == 2
  13. assert PY3 or PY2
  14. here = os.path.abspath(os.path.dirname(__file__))
  15. version_file = os.path.join(here, 'labelme', '_version.py')
  16. if PY3:
  17. import importlib
  18. version = importlib.machinery.SourceFileLoader(
  19. '_version', version_file
  20. ).load_module().__version__
  21. else:
  22. assert PY2
  23. import imp
  24. version = imp.load_source('_version', version_file).__version__
  25. del here
  26. install_requires = [
  27. 'lxml',
  28. 'matplotlib',
  29. 'numpy',
  30. 'Pillow>=2.8.0',
  31. 'PyYAML',
  32. 'qtpy',
  33. ]
  34. # Find python binding for qt with priority:
  35. # PyQt5 -> PySide2 -> PyQt4,
  36. # and PyQt5 is automatically installed on Python3.
  37. QT_BINDING = None
  38. try:
  39. import PyQt5 # NOQA
  40. QT_BINDING = 'pyqt5'
  41. except ImportError:
  42. pass
  43. if QT_BINDING is None:
  44. try:
  45. import PySide2 # NOQA
  46. QT_BINDING = 'pyside2'
  47. except ImportError:
  48. pass
  49. if QT_BINDING is None:
  50. try:
  51. import PyQt4 # NOQA
  52. QT_BINDING = 'pyqt4'
  53. except ImportError:
  54. if PY2:
  55. print(
  56. 'Please install PyQt5, PySide2 or PyQt4 for Python2.\n'
  57. 'Note that PyQt5 can be installed via pip for Python3.',
  58. file=sys.stderr,
  59. )
  60. sys.exit(1)
  61. assert PY3
  62. # PyQt5 can be installed via pip for Python3
  63. install_requires.append('PyQt5')
  64. QT_BINDING = 'pyqt5'
  65. del QT_BINDING
  66. if sys.argv[1] == 'release':
  67. if not distutils.spawn.find_executable('twine'):
  68. print(
  69. 'Please install twine:\n\n\tpip install twine\n',
  70. file=sys.stderr,
  71. )
  72. sys.exit(1)
  73. commands = [
  74. 'git tag v{:s}'.format(version),
  75. 'git push origin master --tag',
  76. 'python setup.py sdist',
  77. 'twine upload dist/labelme-{:s}.tar.gz'.format(version),
  78. ]
  79. for cmd in commands:
  80. subprocess.check_call(shlex.split(cmd))
  81. sys.exit(0)
  82. with open('README.md') as f:
  83. long_description = github2pypi.replace_url(
  84. slug='wkentaro/labelme', content=f.read()
  85. )
  86. setup(
  87. name='labelme',
  88. version=version,
  89. packages=find_packages(),
  90. description='Image Polygonal Annotation with Python',
  91. long_description=long_description,
  92. long_description_content_type='text/markdown',
  93. author='Kentaro Wada',
  94. author_email='www.kentaro.wada@gmail.com',
  95. url='https://github.com/wkentaro/labelme',
  96. install_requires=install_requires,
  97. license='GPLv3',
  98. keywords='Image Annotation, Machine Learning',
  99. classifiers=[
  100. 'Development Status :: 5 - Production/Stable',
  101. 'Intended Audience :: Developers',
  102. 'Natural Language :: English',
  103. 'Programming Language :: Python',
  104. 'Programming Language :: Python :: 2',
  105. 'Programming Language :: Python :: 3',
  106. 'Programming Language :: Python :: Implementation :: CPython',
  107. 'Programming Language :: Python :: Implementation :: PyPy',
  108. ],
  109. package_data={'labelme': ['icons/*', 'config/*.yaml']},
  110. entry_points={
  111. 'console_scripts': [
  112. 'labelme=labelme.main:main',
  113. 'labelme_draw_json=labelme.cli.draw_json:main',
  114. 'labelme_draw_label_png=labelme.cli.draw_label_png:main',
  115. 'labelme_json_to_dataset=labelme.cli.json_to_dataset:main',
  116. 'labelme_on_docker=labelme.cli.on_docker:main',
  117. ],
  118. },
  119. )