forked from omni-us/jsonargparse
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetup.py
executable file
·55 lines (43 loc) · 1.65 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
#!/usr/bin/env python3
import re
from contextlib import suppress
from pathlib import Path
from setuptools import Command, setup
## Use README.rst for the package long description ##
LONG_DESCRIPTION = re.sub(
':class:|:func:|:ref:|:py:meth:|:py:mod:|py:attr:| *# doctest:.*',
'',
Path('README.rst').read_text(),
)
LONG_DESCRIPTION = re.sub('([+|][- ]{12})[- ]{5}', r'\1', LONG_DESCRIPTION)
LONG_DESCRIPTION_LINES = []
skip_line = False
lines = LONG_DESCRIPTION.split('\n')
for num, line in enumerate(lines):
if (
any(line.startswith('.. '+x) for x in ['doctest:: :hide:', 'testsetup::', 'testcleanup::']) or
(line.startswith('.. testcode::') and ':hide:' in lines[num+1])
):
skip_line = True
elif skip_line and line != '' and not line.startswith(' '):
skip_line = False
if not skip_line:
LONG_DESCRIPTION_LINES.append(line)
LONG_DESCRIPTION = '\n'.join(LONG_DESCRIPTION_LINES)
LONG_DESCRIPTION = re.sub('(testcode::|doctest::).*', 'code-block:: python', LONG_DESCRIPTION)
## test_coverage target ##
CMDCLASS = {}
class CoverageCommand(Command):
description = 'run test coverage and generate html report'
user_options = [] # type: ignore
def initialize_options(self): pass
def finalize_options(self): pass
def run(self):
__import__('jsonargparse_tests.__main__').__main__.run_test_coverage()
CMDCLASS['test_coverage'] = CoverageCommand
## build_sphinx target ##
with suppress(ImportError):
from sphinx.setup_command import BuildDoc
CMDCLASS['build_sphinx'] = BuildDoc # type: ignore
## Run setuptools setup ##
setup(long_description=LONG_DESCRIPTION, cmdclass=CMDCLASS)