-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathsetup.py
82 lines (72 loc) · 2.62 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
import logging
import os.path
import re
import setuptools
def get_package_dir():
pkg_dir = {
'data_juicer.tools': 'tools',
}
return pkg_dir
def get_install_requirements(require_f_paths, env_dir='environments'):
reqs = []
for path in require_f_paths:
target_f = os.path.join(env_dir, path)
if not os.path.exists(target_f):
logging.warning(f'target file does not exist: {target_f}')
else:
with open(target_f, 'r', encoding='utf-8') as fin:
reqs += [x.strip() for x in fin.read().splitlines()]
reqs = [x for x in reqs if not x.startswith('#')]
return reqs
# allowing selective installment based on users' needs
# TODO: The specific taxonomy and dependencies will be determined
# after implementing some preliminary operators and detailed discussions
min_requires = get_install_requirements(['minimal_requires.txt'])
extra_requires = {
'mini':
min_requires,
'sci':
get_install_requirements(['science_requires.txt']),
'dist':
get_install_requirements(['dist_requires.txt']),
'dev':
get_install_requirements(['dev_requires.txt']),
'tools':
get_install_requirements(
['preprocess_requires.txt', 'quality_classifier_requires.txt']),
}
extra_requires['all'] = [v for v in extra_requires.values()]
extra_requires['sandbox'] = get_install_requirements(['sandbox_requires.txt'])
with open('data_juicer/__init__.py', 'r') as f:
version = re.search(r'^__version__\s*=\s*[\'"]([^\'"]*)[\'"]', f.read(),
re.MULTILINE).group(1)
with open('README.md', encoding='utf-8') as f:
readme_md = f.read()
setuptools.setup(
name='py-data-juicer',
version=version,
url='https://github.com/alibaba/data-juicer',
author='SysML Team of Alibaba Tongyi Lab',
description='A One-Stop Data Processing System for Large Language '
'Models.',
long_description=readme_md,
long_description_content_type='text/markdown',
license='Apache License 2.0',
packages=setuptools.find_packages(exclude=['tests*', 'tools*']) +
list(get_package_dir().keys()),
package_dir=get_package_dir(),
entry_points={
'console_scripts': [
'dj-process = data_juicer.tools.process_data:main',
'dj-analyze = data_juicer.tools.analyze_data:main',
'dj-install = data_juicer.tools.dj_install:main',
]
},
install_requires=min_requires,
extras_require=extra_requires,
classifiers=[
'License :: OSI Approved :: Apache Software License',
'Programming Language :: Python :: 3',
'Operating System :: OS Independent'
],
)