setup.py 3.1 KB

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