-
Notifications
You must be signed in to change notification settings - Fork 3
/
setup.py
137 lines (120 loc) · 4.22 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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
from __future__ import print_function
import distutils.spawn
import re
from setuptools import find_packages
from setuptools import setup
import shlex
import subprocess
import sys
import yaml
def get_version():
filename = 'labelme/__init__.py'
with open(filename) as f:
match = re.search(
r'''^__version__ = ['"]([^'"]*)['"]''', f.read(), re.M
)
if not match:
raise RuntimeError("{} doesn't contain __version__".format(filename))
version = match.groups()[0]
return version
def update_config_for_version():
version = get_version()
config_file = 'labelme/config/default_config.yaml'
with open(config_file) as f:
config = yaml.safe_load(f)
config['version'] = version
with open(config_file, 'w') as f:
yaml.dump(config, f)
def get_install_requires():
PY3 = sys.version_info[0] == 3
PY2 = sys.version_info[0] == 2
assert PY3 or PY2
install_requires = [
'imgviz>=0.11.0',
'matplotlib',
'numpy',
'Pillow>=2.8.0',
'PyYAML',
'qtpy',
'termcolor',
'opencv-contrib-python',
'torch',
'torchvision'
]
# Find python binding for qt with priority:
# PyQt5 -> PySide2 -> PyQt4,
# and PyQt5 is automatically installed on Python3.
QT_BINDING = None
try:
import PyQt5 # NOQA
QT_BINDING = 'pyqt5'
except ImportError:
pass
if QT_BINDING is None:
try:
import PySide2 # NOQA
QT_BINDING = 'pyside2'
except ImportError:
pass
if QT_BINDING is None:
try:
import PyQt4 # NOQA
QT_BINDING = 'pyqt4'
except ImportError:
if PY2:
print(
'Please install PyQt5, PySide2 or PyQt4 for Python2.\n'
'Note that PyQt5 can be installed via pip for Python3.',
file=sys.stderr,
)
sys.exit(1)
assert PY3
# PyQt5 can be installed via pip for Python3
install_requires.append('PyQt5')
QT_BINDING = 'pyqt5'
del QT_BINDING
return install_requires
def main():
version = get_version()
update_config_for_version()
setup(
name='smarter-labelme',
version=version,
packages=find_packages(exclude=['github2pypi']),
description='Smarter Image Annotation with Python and Re3',
long_description="Refer to https://github.com/robot-perception-group/smarter-labelme for usage.",
long_description_content_type='text/markdown',
author='Eric Price',
author_email='[email protected]',
url='https://github.com/robot-perception-group/smarter-labelme',
install_requires=get_install_requires(),
license='GPLv3',
keywords='Image Annotation, Machine Learning',
classifiers=[
'Development Status :: 5 - Production/Stable',
'Intended Audience :: Developers',
'Natural Language :: English',
'Programming Language :: Python',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
'Programming Language :: Python :: 3.7',
'Programming Language :: Python :: Implementation :: CPython',
'Programming Language :: Python :: Implementation :: PyPy',
],
package_data={'labelme': ['icons/*', 'config/*.yaml', 'doc/*']},
entry_points={
'console_scripts': [
'smarter_labelme=labelme.__main__:main',
'smarter_labelme_draw_json=labelme.cli.draw_json:main',
'smarter_labelme_draw_overlay=labelme.cli.draw_overlay:main',
'smarter_labelme2mask=labelme.cli.labelme2mask:main',
'smarter_labelme_draw_label_png=labelme.cli.draw_label_png:main',
'smarter_labelme_json_to_dataset=labelme.cli.json_to_dataset:main',
'smarter_labelme_video2frames=labelme.cli.video2frames:main',
'smarter_labelme_convert_fps=labelme.cli.convert_fps:main',
],
},
)
if __name__ == '__main__':
main()