| | |
| | |
| | import os |
| | from setuptools import find_packages, setup |
| | from typing import List |
| |
|
| |
|
| | def readme(): |
| | with open('README.md', encoding='utf-8') as f: |
| | content = f.read() |
| | return content |
| |
|
| |
|
| | version_file = 'swift/version.py' |
| |
|
| |
|
| | def get_version(): |
| | with open(version_file, 'r', encoding='utf-8') as f: |
| | exec(compile(f.read(), version_file, 'exec')) |
| | return locals()['__version__'] |
| |
|
| |
|
| | def parse_requirements(fname='requirements.txt', with_version=True): |
| | """ |
| | Parse the package dependencies listed in a requirements file but strips |
| | specific versioning information. |
| | |
| | Args: |
| | fname (str): path to requirements file |
| | with_version (bool, default=False): if True include version specs |
| | |
| | Returns: |
| | List[str]: list of requirements items |
| | |
| | CommandLine: |
| | python -c "import setup; print(setup.parse_requirements())" |
| | """ |
| | import re |
| | import sys |
| | from os.path import exists |
| | require_fpath = fname |
| |
|
| | def parse_line(line): |
| | """ |
| | Parse information from a line in a requirements text file |
| | """ |
| | if line.startswith('-r '): |
| | |
| | target = line.split(' ')[1] |
| | relative_base = os.path.dirname(fname) |
| | absolute_target = os.path.join(relative_base, target) |
| | for info in parse_require_file(absolute_target): |
| | yield info |
| | else: |
| | info = {'line': line} |
| | if line.startswith('-e '): |
| | info['package'] = line.split('#egg=')[1] |
| | else: |
| | |
| | pat = '(' + '|'.join(['>=', '==', '>']) + ')' |
| | parts = re.split(pat, line, maxsplit=1) |
| | parts = [p.strip() for p in parts] |
| |
|
| | info['package'] = parts[0] |
| | if len(parts) > 1: |
| | op, rest = parts[1:] |
| | if ';' in rest: |
| | |
| | |
| | version, platform_deps = map(str.strip, rest.split(';')) |
| | info['platform_deps'] = platform_deps |
| | else: |
| | version = rest |
| | info['version'] = (op, version) |
| | yield info |
| |
|
| | def parse_require_file(fpath): |
| | with open(fpath, 'r', encoding='utf-8') as f: |
| | for line in f.readlines(): |
| | line = line.strip() |
| | if line.startswith('http'): |
| | print('skip http requirements %s' % line) |
| | continue |
| | if line and not line.startswith('#') and not line.startswith('--'): |
| | for info in parse_line(line): |
| | yield info |
| | elif line and line.startswith('--find-links'): |
| | eles = line.split() |
| | for e in eles: |
| | e = e.strip() |
| | if 'http' in e: |
| | info = dict(dependency_links=e) |
| | yield info |
| |
|
| | def gen_packages_items(): |
| | items = [] |
| | deps_link = [] |
| | if exists(require_fpath): |
| | for info in parse_require_file(require_fpath): |
| | if 'dependency_links' not in info: |
| | parts = [info['package']] |
| | if with_version and 'version' in info: |
| | parts.extend(info['version']) |
| | if not sys.version.startswith('3.4'): |
| | |
| | platform_deps = info.get('platform_deps') |
| | if platform_deps is not None: |
| | parts.append(';' + platform_deps) |
| | item = ''.join(parts) |
| | items.append(item) |
| | else: |
| | deps_link.append(info['dependency_links']) |
| | return items, deps_link |
| |
|
| | return gen_packages_items() |
| |
|
| |
|
| | if __name__ == '__main__': |
| | install_requires, deps_link = parse_requirements('requirements.txt') |
| | extra_requires = {} |
| | all_requires = [] |
| | extra_requires['eval'], _ = parse_requirements('requirements/eval.txt') |
| | extra_requires['swanlab'], _ = parse_requirements('requirements/swanlab.txt') |
| | extra_requires['seq_parallel'], _ = parse_requirements('requirements/seq_parallel.txt') |
| | all_requires.extend(install_requires) |
| | all_requires.extend(extra_requires['eval']) |
| | all_requires.extend(extra_requires['seq_parallel']) |
| | all_requires.extend(extra_requires['swanlab']) |
| | extra_requires['all'] = all_requires |
| |
|
| | setup( |
| | name='ms_swift', |
| | version=get_version(), |
| | description='Swift: Scalable lightWeight Infrastructure for Fine-Tuning', |
| | long_description=readme(), |
| | long_description_content_type='text/markdown', |
| | author='DAMO ModelScope teams', |
| | author_email='contact@modelscope.cn', |
| | keywords='python, petl, efficient tuners', |
| | url='https://github.com/modelscope/swift', |
| | packages=find_packages(exclude=('configs', 'demo')), |
| | include_package_data=True, |
| | package_data={ |
| | '': ['*.h', '*.cpp', '*.cu'], |
| | }, |
| | classifiers=[ |
| | 'Development Status :: 4 - Beta', |
| | 'License :: OSI Approved :: Apache Software License', |
| | 'Operating System :: OS Independent', |
| | 'Programming Language :: Python :: 3', |
| | 'Programming Language :: Python :: 3.8', |
| | 'Programming Language :: Python :: 3.9', |
| | 'Programming Language :: Python :: 3.10', |
| | 'Programming Language :: Python :: 3.11', |
| | 'Programming Language :: Python :: 3.12', |
| | ], |
| | license='Apache License 2.0', |
| | tests_require=parse_requirements('requirements/tests.txt'), |
| | install_requires=install_requires, |
| | extras_require=extra_requires, |
| | entry_points={ |
| | 'console_scripts': ['swift=swift.cli.main:cli_main', 'megatron=swift.cli._megatron.main:cli_main'] |
| | }, |
| | dependency_links=deps_link, |
| | zip_safe=False) |
| |
|