py2docfx 0.1.11.dev1830301__py3-none-any.whl → 0.1.11.dev1860114__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- py2docfx/__main__.py +3 -49
- py2docfx/convert_prepare/pip_utils.py +1 -1
- py2docfx/venv/0/Lib/site-packages/_distutils_hack/__init__.py +3 -4
- py2docfx/venv/0/Lib/site-packages/certifi/__init__.py +1 -1
- py2docfx/venv/0/Lib/site-packages/idna/__init__.py +2 -1
- py2docfx/venv/0/Lib/site-packages/idna/codec.py +31 -27
- py2docfx/venv/0/Lib/site-packages/idna/compat.py +6 -4
- py2docfx/venv/0/Lib/site-packages/idna/core.py +161 -119
- py2docfx/venv/0/Lib/site-packages/idna/idnadata.py +3537 -3539
- py2docfx/venv/0/Lib/site-packages/idna/intranges.py +7 -4
- py2docfx/venv/0/Lib/site-packages/idna/package_data.py +1 -2
- py2docfx/venv/0/Lib/site-packages/idna/uts46data.py +8261 -8178
- py2docfx/venv/0/Lib/site-packages/pkg_resources/__init__.py +145 -135
- py2docfx/venv/0/Lib/site-packages/pkg_resources/tests/test_find_distributions.py +3 -2
- py2docfx/venv/0/Lib/site-packages/pkg_resources/tests/test_pkg_resources.py +12 -17
- py2docfx/venv/0/Lib/site-packages/pkg_resources/tests/test_resources.py +12 -12
- py2docfx/venv/0/Lib/site-packages/pkg_resources/tests/test_working_set.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/__init__.py +67 -36
- py2docfx/venv/0/Lib/site-packages/setuptools/_core_metadata.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_modified.py +3 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_msvccompiler.py +75 -39
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/archive_util.py +5 -24
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/ccompiler.py +2 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/__init__.py +0 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/build_ext.py +1 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/install.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/install_lib.py +3 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/sdist.py +1 -13
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/core.py +1 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/cygwinccompiler.py +11 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/dir_util.py +120 -109
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/dist.py +8 -18
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/errors.py +5 -8
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/extension.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/file_util.py +2 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/sysconfig.py +3 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_archive_util.py +0 -33
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_dir_util.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_modified.py +7 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_msvccompiler.py +33 -10
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_sdist.py +4 -13
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/util.py +2 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_entry_points.py +5 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/_imp.py +2 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/_importlib.py +0 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/_path.py +9 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/_reqs.py +10 -7
- py2docfx/venv/0/Lib/site-packages/setuptools/_vendor/jaraco/collections/__init__.py +1091 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/archive_util.py +6 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/build_meta.py +15 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/command/__init__.py +2 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/command/_requirestxt.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/command/alias.py +2 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/command/bdist_egg.py +8 -7
- py2docfx/venv/0/Lib/site-packages/setuptools/command/bdist_rpm.py +5 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/command/bdist_wheel.py +72 -34
- py2docfx/venv/0/Lib/site-packages/setuptools/command/build.py +11 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/command/build_clib.py +8 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/command/build_ext.py +32 -23
- py2docfx/venv/0/Lib/site-packages/setuptools/command/build_py.py +11 -8
- py2docfx/venv/0/Lib/site-packages/setuptools/command/develop.py +8 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/command/dist_info.py +3 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/command/easy_install.py +100 -74
- py2docfx/venv/0/Lib/site-packages/setuptools/command/editable_wheel.py +48 -36
- py2docfx/venv/0/Lib/site-packages/setuptools/command/egg_info.py +16 -25
- py2docfx/venv/0/Lib/site-packages/setuptools/command/install.py +9 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/command/install_egg_info.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/command/install_lib.py +8 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/command/install_scripts.py +7 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/command/rotate.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/command/sdist.py +16 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/command/setopt.py +6 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/command/test.py +4 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/compat/py310.py +0 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/compat/py311.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/compat/py312.py +13 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/config/_apply_pyprojecttoml.py +37 -16
- py2docfx/venv/0/Lib/site-packages/setuptools/config/_validate_pyproject/error_reporting.py +2 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/config/_validate_pyproject/fastjsonschema_validations.py +266 -51
- py2docfx/venv/0/Lib/site-packages/setuptools/config/_validate_pyproject/formats.py +23 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/config/expand.py +18 -18
- py2docfx/venv/0/Lib/site-packages/setuptools/config/pyprojecttoml.py +20 -7
- py2docfx/venv/0/Lib/site-packages/setuptools/config/setupcfg.py +12 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/depends.py +4 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/discovery.py +2 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/dist.py +24 -19
- py2docfx/venv/0/Lib/site-packages/setuptools/errors.py +23 -17
- py2docfx/venv/0/Lib/site-packages/setuptools/extension.py +22 -8
- py2docfx/venv/0/Lib/site-packages/setuptools/glob.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/installer.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/launch.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/logging.py +4 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/modified.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/monkey.py +19 -50
- py2docfx/venv/0/Lib/site-packages/setuptools/msvc.py +118 -350
- py2docfx/venv/0/Lib/site-packages/setuptools/namespaces.py +6 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/package_index.py +35 -35
- py2docfx/venv/0/Lib/site-packages/setuptools/sandbox.py +30 -31
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/__init__.py +4 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/compat/py39.py +0 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/config/downloads/preload.py +0 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/config/test_apply_pyprojecttoml.py +51 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/config/test_expand.py +2 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/config/test_pyprojecttoml.py +3 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/config/test_setupcfg.py +6 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/contexts.py +4 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/environment.py +2 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/fixtures.py +3 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/integration/helpers.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/integration/test_pip_install_sdist.py +3 -4
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/server.py +2 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_archive_util.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_bdist_deprecations.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_bdist_wheel.py +27 -17
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_build.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_build_clib.py +3 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_build_ext.py +5 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_build_meta.py +12 -15
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_build_py.py +2 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_config_discovery.py +13 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_core_metadata.py +4 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_develop.py +5 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_dist.py +10 -11
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_dist_info.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_distutils_adoption.py +1 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_easy_install.py +28 -18
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_editable_install.py +9 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_egg_info.py +4 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_extern.py +4 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_find_packages.py +1 -2
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_find_py_modules.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_install_scripts.py +1 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_logging.py +3 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_manifest.py +7 -7
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_namespaces.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_packageindex.py +4 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_sandbox.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_sdist.py +76 -11
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_setuptools.py +8 -8
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_virtualenv.py +3 -5
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_warnings.py +0 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_wheel.py +9 -9
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_windows_wrappers.py +3 -3
- py2docfx/venv/0/Lib/site-packages/setuptools/unicode_utils.py +1 -1
- py2docfx/venv/0/Lib/site-packages/setuptools/wheel.py +5 -6
- py2docfx/venv/0/Lib/site-packages/setuptools/windows_support.py +2 -2
- py2docfx/venv/0/Lib/site-packages/urllib3/_request_methods.py +2 -3
- py2docfx/venv/0/Lib/site-packages/urllib3/_version.py +15 -3
- py2docfx/venv/0/Lib/site-packages/urllib3/connection.py +158 -54
- py2docfx/venv/0/Lib/site-packages/urllib3/contrib/pyopenssl.py +4 -0
- py2docfx/venv/0/Lib/site-packages/urllib3/http2/__init__.py +53 -0
- py2docfx/venv/0/Lib/site-packages/urllib3/http2/connection.py +356 -0
- py2docfx/venv/0/Lib/site-packages/urllib3/http2/probe.py +87 -0
- py2docfx/venv/0/Lib/site-packages/urllib3/util/connection.py +1 -1
- py2docfx/venv/0/Lib/site-packages/urllib3/util/request.py +1 -1
- py2docfx/venv/0/Lib/site-packages/urllib3/util/ssl_.py +12 -8
- py2docfx/venv/0/Lib/site-packages/urllib3/util/ssltransport.py +0 -3
- py2docfx/venv/0/Scripts/rst2html.py +1 -1
- py2docfx/venv/0/Scripts/rst2html4.py +1 -1
- py2docfx/venv/0/Scripts/rst2html5.py +1 -1
- py2docfx/venv/0/Scripts/rst2latex.py +1 -1
- py2docfx/venv/0/Scripts/rst2man.py +1 -1
- py2docfx/venv/0/Scripts/rst2odt.py +1 -1
- py2docfx/venv/0/Scripts/rst2odt_prepstyles.py +1 -1
- py2docfx/venv/0/Scripts/rst2pseudoxml.py +1 -1
- py2docfx/venv/0/Scripts/rst2s5.py +1 -1
- py2docfx/venv/0/Scripts/rst2xetex.py +1 -1
- py2docfx/venv/0/Scripts/rst2xml.py +1 -1
- py2docfx/venv/0/Scripts/rstpep2html.py +1 -1
- {py2docfx-0.1.11.dev1830301.dist-info → py2docfx-0.1.11.dev1860114.dist-info}/METADATA +1 -1
- py2docfx-0.1.11.dev1860114.dist-info/RECORD +1889 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_collections.py +0 -58
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_functools.py +0 -73
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_itertools.py +0 -52
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/__init__.py +0 -0
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/__init__.py +0 -15
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_elffile.py +0 -108
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_manylinux.py +0 -260
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_musllinux.py +0 -83
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_parser.py +0 -356
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_structures.py +0 -61
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_tokenizer.py +0 -192
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/markers.py +0 -252
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/metadata.py +0 -825
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/requirements.py +0 -90
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/specifiers.py +0 -1017
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/tags.py +0 -571
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/utils.py +0 -172
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/_vendor/packaging/version.py +0 -563
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/bcppcompiler.py +0 -396
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/register.py +0 -322
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/command/upload.py +0 -208
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/config.py +0 -151
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/msvc9compiler.py +0 -822
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/msvccompiler.py +0 -687
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_config.py +0 -116
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_msvc9compiler.py +0 -184
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_register.py +0 -314
- py2docfx/venv/0/Lib/site-packages/setuptools/_distutils/tests/test_upload.py +0 -215
- py2docfx/venv/0/Lib/site-packages/setuptools/_vendor/ordered_set/__init__.py +0 -536
- py2docfx/venv/0/Lib/site-packages/setuptools/command/register.py +0 -18
- py2docfx/venv/0/Lib/site-packages/setuptools/command/upload.py +0 -17
- py2docfx/venv/0/Lib/site-packages/setuptools/command/upload_docs.py +0 -221
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_integration.py +0 -122
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_msvc14.py +0 -83
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_register.py +0 -19
- py2docfx/venv/0/Lib/site-packages/setuptools/tests/test_upload.py +0 -19
- py2docfx/venv/0/Lib/site-packages/urllib3/http2.py +0 -230
- py2docfx/venv/template/Lib/site-packages/_distutils_hack/__init__.py +0 -241
- py2docfx/venv/template/Lib/site-packages/_distutils_hack/override.py +0 -1
- py2docfx/venv/template/Lib/site-packages/_yaml/__init__.py +0 -33
- py2docfx/venv/template/Lib/site-packages/alabaster/__init__.py +0 -35
- py2docfx/venv/template/Lib/site-packages/alabaster/support.py +0 -89
- py2docfx/venv/template/Lib/site-packages/babel/__init__.py +0 -37
- py2docfx/venv/template/Lib/site-packages/babel/core.py +0 -1300
- py2docfx/venv/template/Lib/site-packages/babel/dates.py +0 -1925
- py2docfx/venv/template/Lib/site-packages/babel/languages.py +0 -72
- py2docfx/venv/template/Lib/site-packages/babel/lists.py +0 -123
- py2docfx/venv/template/Lib/site-packages/babel/localedata.py +0 -278
- py2docfx/venv/template/Lib/site-packages/babel/localtime/__init__.py +0 -43
- py2docfx/venv/template/Lib/site-packages/babel/localtime/_fallback.py +0 -44
- py2docfx/venv/template/Lib/site-packages/babel/localtime/_helpers.py +0 -57
- py2docfx/venv/template/Lib/site-packages/babel/localtime/_unix.py +0 -98
- py2docfx/venv/template/Lib/site-packages/babel/localtime/_win32.py +0 -98
- py2docfx/venv/template/Lib/site-packages/babel/messages/__init__.py +0 -21
- py2docfx/venv/template/Lib/site-packages/babel/messages/_compat.py +0 -34
- py2docfx/venv/template/Lib/site-packages/babel/messages/catalog.py +0 -952
- py2docfx/venv/template/Lib/site-packages/babel/messages/checkers.py +0 -168
- py2docfx/venv/template/Lib/site-packages/babel/messages/extract.py +0 -843
- py2docfx/venv/template/Lib/site-packages/babel/messages/frontend.py +0 -1203
- py2docfx/venv/template/Lib/site-packages/babel/messages/jslexer.py +0 -203
- py2docfx/venv/template/Lib/site-packages/babel/messages/mofile.py +0 -212
- py2docfx/venv/template/Lib/site-packages/babel/messages/plurals.py +0 -257
- py2docfx/venv/template/Lib/site-packages/babel/messages/pofile.py +0 -675
- py2docfx/venv/template/Lib/site-packages/babel/messages/setuptools_frontend.py +0 -108
- py2docfx/venv/template/Lib/site-packages/babel/numbers.py +0 -1573
- py2docfx/venv/template/Lib/site-packages/babel/plural.py +0 -640
- py2docfx/venv/template/Lib/site-packages/babel/support.py +0 -726
- py2docfx/venv/template/Lib/site-packages/babel/units.py +0 -343
- py2docfx/venv/template/Lib/site-packages/babel/util.py +0 -269
- py2docfx/venv/template/Lib/site-packages/certifi/__init__.py +0 -4
- py2docfx/venv/template/Lib/site-packages/certifi/__main__.py +0 -12
- py2docfx/venv/template/Lib/site-packages/certifi/core.py +0 -114
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/__init__.py +0 -46
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/__main__.py +0 -4
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/api.py +0 -626
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/cd.py +0 -395
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/cli/__init__.py +0 -6
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/cli/__main__.py +0 -296
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/constant.py +0 -1995
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/legacy.py +0 -54
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/md.py +0 -615
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/models.py +0 -340
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/utils.py +0 -421
- py2docfx/venv/template/Lib/site-packages/charset_normalizer/version.py +0 -6
- py2docfx/venv/template/Lib/site-packages/colorama/__init__.py +0 -7
- py2docfx/venv/template/Lib/site-packages/colorama/ansi.py +0 -102
- py2docfx/venv/template/Lib/site-packages/colorama/ansitowin32.py +0 -277
- py2docfx/venv/template/Lib/site-packages/colorama/initialise.py +0 -121
- py2docfx/venv/template/Lib/site-packages/colorama/tests/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/colorama/tests/ansi_test.py +0 -76
- py2docfx/venv/template/Lib/site-packages/colorama/tests/ansitowin32_test.py +0 -294
- py2docfx/venv/template/Lib/site-packages/colorama/tests/initialise_test.py +0 -189
- py2docfx/venv/template/Lib/site-packages/colorama/tests/isatty_test.py +0 -57
- py2docfx/venv/template/Lib/site-packages/colorama/tests/utils.py +0 -49
- py2docfx/venv/template/Lib/site-packages/colorama/tests/winterm_test.py +0 -131
- py2docfx/venv/template/Lib/site-packages/colorama/win32.py +0 -180
- py2docfx/venv/template/Lib/site-packages/colorama/winterm.py +0 -195
- py2docfx/venv/template/Lib/site-packages/docutils/__init__.py +0 -284
- py2docfx/venv/template/Lib/site-packages/docutils/__main__.py +0 -96
- py2docfx/venv/template/Lib/site-packages/docutils/core.py +0 -714
- py2docfx/venv/template/Lib/site-packages/docutils/examples.py +0 -99
- py2docfx/venv/template/Lib/site-packages/docutils/frontend.py +0 -951
- py2docfx/venv/template/Lib/site-packages/docutils/io.py +0 -611
- py2docfx/venv/template/Lib/site-packages/docutils/languages/__init__.py +0 -83
- py2docfx/venv/template/Lib/site-packages/docutils/languages/af.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/ar.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/ca.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/cs.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/da.py +0 -61
- py2docfx/venv/template/Lib/site-packages/docutils/languages/de.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/en.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/eo.py +0 -61
- py2docfx/venv/template/Lib/site-packages/docutils/languages/es.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/fa.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/fi.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/fr.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/gl.py +0 -62
- py2docfx/venv/template/Lib/site-packages/docutils/languages/he.py +0 -61
- py2docfx/venv/template/Lib/site-packages/docutils/languages/it.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/ja.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/ko.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/lt.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/lv.py +0 -59
- py2docfx/venv/template/Lib/site-packages/docutils/languages/nl.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/pl.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/pt_br.py +0 -60
- py2docfx/venv/template/Lib/site-packages/docutils/languages/ru.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/sk.py +0 -58
- py2docfx/venv/template/Lib/site-packages/docutils/languages/sv.py +0 -59
- py2docfx/venv/template/Lib/site-packages/docutils/languages/zh_cn.py +0 -66
- py2docfx/venv/template/Lib/site-packages/docutils/languages/zh_tw.py +0 -65
- py2docfx/venv/template/Lib/site-packages/docutils/nodes.py +0 -2314
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/__init__.py +0 -92
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/commonmark_wrapper.py +0 -56
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/null.py +0 -20
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/recommonmark_wrapper.py +0 -136
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/__init__.py +0 -414
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/__init__.py +0 -460
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/admonitions.py +0 -99
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/body.py +0 -304
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/html.py +0 -21
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/images.py +0 -163
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/misc.py +0 -635
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/parts.py +0 -126
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/references.py +0 -29
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/directives/tables.py +0 -513
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/__init__.py +0 -40
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/af.py +0 -107
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/ar.py +0 -99
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/ca.py +0 -126
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/cs.py +0 -110
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/da.py +0 -113
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/de.py +0 -106
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/en.py +0 -111
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/eo.py +0 -118
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/es.py +0 -122
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/fa.py +0 -102
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/fi.py +0 -98
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/fr.py +0 -104
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/gl.py +0 -111
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/he.py +0 -109
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/it.py +0 -98
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/ja.py +0 -119
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/ko.py +0 -111
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/lt.py +0 -109
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/lv.py +0 -108
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/nl.py +0 -113
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/pl.py +0 -100
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/pt_br.py +0 -109
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/ru.py +0 -90
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/sk.py +0 -96
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/sv.py +0 -96
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/zh_cn.py +0 -104
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/languages/zh_tw.py +0 -109
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/roles.py +0 -439
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/states.py +0 -3135
- py2docfx/venv/template/Lib/site-packages/docutils/parsers/rst/tableparser.py +0 -539
- py2docfx/venv/template/Lib/site-packages/docutils/readers/__init__.py +0 -113
- py2docfx/venv/template/Lib/site-packages/docutils/readers/doctree.py +0 -46
- py2docfx/venv/template/Lib/site-packages/docutils/readers/pep.py +0 -48
- py2docfx/venv/template/Lib/site-packages/docutils/readers/standalone.py +0 -65
- py2docfx/venv/template/Lib/site-packages/docutils/statemachine.py +0 -1525
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/__init__.py +0 -174
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/components.py +0 -54
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/frontmatter.py +0 -545
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/misc.py +0 -144
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/parts.py +0 -176
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/peps.py +0 -308
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/references.py +0 -919
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/universal.py +0 -338
- py2docfx/venv/template/Lib/site-packages/docutils/transforms/writer_aux.py +0 -99
- py2docfx/venv/template/Lib/site-packages/docutils/utils/__init__.py +0 -821
- py2docfx/venv/template/Lib/site-packages/docutils/utils/code_analyzer.py +0 -138
- py2docfx/venv/template/Lib/site-packages/docutils/utils/error_reporting.py +0 -222
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/__init__.py +0 -52
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/latex2mathml.py +0 -1430
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/math2html.py +0 -3171
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/tex2mathml_extern.py +0 -152
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/tex2unichar.py +0 -704
- py2docfx/venv/template/Lib/site-packages/docutils/utils/math/unichar2tex.py +0 -808
- py2docfx/venv/template/Lib/site-packages/docutils/utils/punctuation_chars.py +0 -122
- py2docfx/venv/template/Lib/site-packages/docutils/utils/roman.py +0 -86
- py2docfx/venv/template/Lib/site-packages/docutils/utils/smartquotes.py +0 -991
- py2docfx/venv/template/Lib/site-packages/docutils/utils/urischemes.py +0 -138
- py2docfx/venv/template/Lib/site-packages/docutils/writers/__init__.py +0 -151
- py2docfx/venv/template/Lib/site-packages/docutils/writers/_html_base.py +0 -1781
- py2docfx/venv/template/Lib/site-packages/docutils/writers/docutils_xml.py +0 -188
- py2docfx/venv/template/Lib/site-packages/docutils/writers/html4css1/__init__.py +0 -947
- py2docfx/venv/template/Lib/site-packages/docutils/writers/html5_polyglot/__init__.py +0 -454
- py2docfx/venv/template/Lib/site-packages/docutils/writers/latex2e/__init__.py +0 -3295
- py2docfx/venv/template/Lib/site-packages/docutils/writers/manpage.py +0 -1181
- py2docfx/venv/template/Lib/site-packages/docutils/writers/null.py +0 -21
- py2docfx/venv/template/Lib/site-packages/docutils/writers/odf_odt/__init__.py +0 -3468
- py2docfx/venv/template/Lib/site-packages/docutils/writers/odf_odt/pygmentsformatter.py +0 -109
- py2docfx/venv/template/Lib/site-packages/docutils/writers/pep_html/__init__.py +0 -103
- py2docfx/venv/template/Lib/site-packages/docutils/writers/pseudoxml.py +0 -40
- py2docfx/venv/template/Lib/site-packages/docutils/writers/s5_html/__init__.py +0 -352
- py2docfx/venv/template/Lib/site-packages/docutils/writers/xetex/__init__.py +0 -149
- py2docfx/venv/template/Lib/site-packages/idna/__init__.py +0 -44
- py2docfx/venv/template/Lib/site-packages/idna/codec.py +0 -118
- py2docfx/venv/template/Lib/site-packages/idna/compat.py +0 -13
- py2docfx/venv/template/Lib/site-packages/idna/core.py +0 -395
- py2docfx/venv/template/Lib/site-packages/idna/idnadata.py +0 -4245
- py2docfx/venv/template/Lib/site-packages/idna/intranges.py +0 -54
- py2docfx/venv/template/Lib/site-packages/idna/package_data.py +0 -2
- py2docfx/venv/template/Lib/site-packages/idna/uts46data.py +0 -8598
- py2docfx/venv/template/Lib/site-packages/imagesize/__init__.py +0 -5
- py2docfx/venv/template/Lib/site-packages/imagesize/imagesize.py +0 -376
- py2docfx/venv/template/Lib/site-packages/imagesize.py +0 -383
- py2docfx/venv/template/Lib/site-packages/jinja2/__init__.py +0 -45
- py2docfx/venv/template/Lib/site-packages/jinja2/_identifier.py +0 -6
- py2docfx/venv/template/Lib/site-packages/jinja2/async_utils.py +0 -75
- py2docfx/venv/template/Lib/site-packages/jinja2/bccache.py +0 -364
- py2docfx/venv/template/Lib/site-packages/jinja2/compiler.py +0 -1957
- py2docfx/venv/template/Lib/site-packages/jinja2/constants.py +0 -20
- py2docfx/venv/template/Lib/site-packages/jinja2/debug.py +0 -259
- py2docfx/venv/template/Lib/site-packages/jinja2/defaults.py +0 -48
- py2docfx/venv/template/Lib/site-packages/jinja2/environment.py +0 -1661
- py2docfx/venv/template/Lib/site-packages/jinja2/exceptions.py +0 -166
- py2docfx/venv/template/Lib/site-packages/jinja2/ext.py +0 -879
- py2docfx/venv/template/Lib/site-packages/jinja2/filters.py +0 -1824
- py2docfx/venv/template/Lib/site-packages/jinja2/idtracking.py +0 -318
- py2docfx/venv/template/Lib/site-packages/jinja2/lexer.py +0 -869
- py2docfx/venv/template/Lib/site-packages/jinja2/loaders.py +0 -652
- py2docfx/venv/template/Lib/site-packages/jinja2/meta.py +0 -111
- py2docfx/venv/template/Lib/site-packages/jinja2/nativetypes.py +0 -124
- py2docfx/venv/template/Lib/site-packages/jinja2/nodes.py +0 -1204
- py2docfx/venv/template/Lib/site-packages/jinja2/optimizer.py +0 -47
- py2docfx/venv/template/Lib/site-packages/jinja2/parser.py +0 -1040
- py2docfx/venv/template/Lib/site-packages/jinja2/runtime.py +0 -1104
- py2docfx/venv/template/Lib/site-packages/jinja2/sandbox.py +0 -428
- py2docfx/venv/template/Lib/site-packages/jinja2/tests.py +0 -255
- py2docfx/venv/template/Lib/site-packages/jinja2/utils.py +0 -854
- py2docfx/venv/template/Lib/site-packages/jinja2/visitor.py +0 -92
- py2docfx/venv/template/Lib/site-packages/markupsafe/__init__.py +0 -332
- py2docfx/venv/template/Lib/site-packages/markupsafe/_native.py +0 -63
- py2docfx/venv/template/Lib/site-packages/packaging/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/packaging/_elffile.py +0 -110
- py2docfx/venv/template/Lib/site-packages/packaging/_manylinux.py +0 -262
- py2docfx/venv/template/Lib/site-packages/packaging/_musllinux.py +0 -85
- py2docfx/venv/template/Lib/site-packages/packaging/_parser.py +0 -354
- py2docfx/venv/template/Lib/site-packages/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/packaging/_tokenizer.py +0 -194
- py2docfx/venv/template/Lib/site-packages/packaging/markers.py +0 -325
- py2docfx/venv/template/Lib/site-packages/packaging/metadata.py +0 -804
- py2docfx/venv/template/Lib/site-packages/packaging/requirements.py +0 -91
- py2docfx/venv/template/Lib/site-packages/packaging/specifiers.py +0 -1009
- py2docfx/venv/template/Lib/site-packages/packaging/tags.py +0 -568
- py2docfx/venv/template/Lib/site-packages/packaging/utils.py +0 -174
- py2docfx/venv/template/Lib/site-packages/packaging/version.py +0 -563
- py2docfx/venv/template/Lib/site-packages/pip/__init__.py +0 -13
- py2docfx/venv/template/Lib/site-packages/pip/__main__.py +0 -24
- py2docfx/venv/template/Lib/site-packages/pip/__pip-runner__.py +0 -50
- py2docfx/venv/template/Lib/site-packages/pip/_internal/__init__.py +0 -18
- py2docfx/venv/template/Lib/site-packages/pip/_internal/build_env.py +0 -311
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cache.py +0 -290
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/__init__.py +0 -4
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/autocompletion.py +0 -172
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/base_command.py +0 -236
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/cmdoptions.py +0 -1074
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/command_context.py +0 -27
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/main.py +0 -79
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/main_parser.py +0 -134
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/parser.py +0 -294
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/progress_bars.py +0 -68
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/req_command.py +0 -505
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/spinners.py +0 -159
- py2docfx/venv/template/Lib/site-packages/pip/_internal/cli/status_codes.py +0 -6
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/__init__.py +0 -132
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/cache.py +0 -225
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/check.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/completion.py +0 -130
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/configuration.py +0 -280
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/debug.py +0 -201
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/download.py +0 -147
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/freeze.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/hash.py +0 -59
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/help.py +0 -41
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/index.py +0 -139
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/inspect.py +0 -92
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/install.py +0 -774
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/list.py +0 -368
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/search.py +0 -174
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/show.py +0 -189
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/uninstall.py +0 -113
- py2docfx/venv/template/Lib/site-packages/pip/_internal/commands/wheel.py +0 -183
- py2docfx/venv/template/Lib/site-packages/pip/_internal/configuration.py +0 -383
- py2docfx/venv/template/Lib/site-packages/pip/_internal/distributions/__init__.py +0 -21
- py2docfx/venv/template/Lib/site-packages/pip/_internal/distributions/base.py +0 -51
- py2docfx/venv/template/Lib/site-packages/pip/_internal/distributions/installed.py +0 -29
- py2docfx/venv/template/Lib/site-packages/pip/_internal/distributions/sdist.py +0 -156
- py2docfx/venv/template/Lib/site-packages/pip/_internal/distributions/wheel.py +0 -40
- py2docfx/venv/template/Lib/site-packages/pip/_internal/exceptions.py +0 -728
- py2docfx/venv/template/Lib/site-packages/pip/_internal/index/__init__.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_internal/index/collector.py +0 -507
- py2docfx/venv/template/Lib/site-packages/pip/_internal/index/package_finder.py +0 -1027
- py2docfx/venv/template/Lib/site-packages/pip/_internal/index/sources.py +0 -285
- py2docfx/venv/template/Lib/site-packages/pip/_internal/locations/__init__.py +0 -467
- py2docfx/venv/template/Lib/site-packages/pip/_internal/locations/_distutils.py +0 -172
- py2docfx/venv/template/Lib/site-packages/pip/_internal/locations/_sysconfig.py +0 -213
- py2docfx/venv/template/Lib/site-packages/pip/_internal/locations/base.py +0 -81
- py2docfx/venv/template/Lib/site-packages/pip/_internal/main.py +0 -12
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/__init__.py +0 -128
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/_json.py +0 -84
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/base.py +0 -702
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +0 -6
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +0 -55
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +0 -227
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +0 -189
- py2docfx/venv/template/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +0 -278
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/__init__.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/candidate.py +0 -30
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/direct_url.py +0 -235
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/format_control.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/index.py +0 -28
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/installation_report.py +0 -56
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/link.py +0 -579
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/scheme.py +0 -31
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/search_scope.py +0 -132
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/selection_prefs.py +0 -51
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/target_python.py +0 -122
- py2docfx/venv/template/Lib/site-packages/pip/_internal/models/wheel.py +0 -92
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/__init__.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/auth.py +0 -561
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/cache.py +0 -106
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/download.py +0 -186
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/lazy_wheel.py +0 -210
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/session.py +0 -520
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/utils.py +0 -96
- py2docfx/venv/template/Lib/site-packages/pip/_internal/network/xmlrpc.py +0 -62
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +0 -139
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/metadata.py +0 -39
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +0 -41
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +0 -74
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/wheel.py +0 -37
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +0 -46
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/check.py +0 -187
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/freeze.py +0 -255
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/install/__init__.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +0 -46
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/install/wheel.py +0 -734
- py2docfx/venv/template/Lib/site-packages/pip/_internal/operations/prepare.py +0 -730
- py2docfx/venv/template/Lib/site-packages/pip/_internal/pyproject.py +0 -179
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/__init__.py +0 -92
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/constructors.py +0 -576
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/req_file.py +0 -554
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/req_install.py +0 -923
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/req_set.py +0 -119
- py2docfx/venv/template/Lib/site-packages/pip/_internal/req/req_uninstall.py +0 -649
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/base.py +0 -20
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +0 -598
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +0 -141
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +0 -597
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +0 -812
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +0 -155
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +0 -255
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +0 -80
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +0 -166
- py2docfx/venv/template/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +0 -317
- py2docfx/venv/template/Lib/site-packages/pip/_internal/self_outdated_check.py +0 -248
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +0 -109
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/_log.py +0 -38
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/appdirs.py +0 -52
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/compat.py +0 -63
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +0 -165
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/datetime.py +0 -11
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/deprecation.py +0 -120
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +0 -87
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/egg_link.py +0 -80
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/encoding.py +0 -36
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/entrypoints.py +0 -84
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/filesystem.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/filetypes.py +0 -27
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/glibc.py +0 -88
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/hashes.py +0 -151
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/logging.py +0 -348
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/misc.py +0 -783
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/models.py +0 -39
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/packaging.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/setuptools_build.py +0 -146
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/subprocess.py +0 -260
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/temp_dir.py +0 -296
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/unpacking.py +0 -257
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/urls.py +0 -62
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/virtualenv.py +0 -104
- py2docfx/venv/template/Lib/site-packages/pip/_internal/utils/wheel.py +0 -134
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/bazaar.py +0 -112
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/git.py +0 -526
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/mercurial.py +0 -163
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/subversion.py +0 -324
- py2docfx/venv/template/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +0 -705
- py2docfx/venv/template/Lib/site-packages/pip/_internal/wheel_builder.py +0 -354
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/__init__.py +0 -121
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +0 -28
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +0 -161
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +0 -74
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +0 -8
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +0 -181
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +0 -48
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +0 -494
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +0 -119
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +0 -154
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +0 -206
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/certifi/__init__.py +0 -4
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/certifi/__main__.py +0 -12
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/certifi/core.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/__init__.py +0 -115
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/big5freq.py +0 -386
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/big5prober.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/chardistribution.py +0 -261
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py +0 -106
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/charsetprober.py +0 -147
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py +0 -112
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py +0 -90
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/codingstatemachinedict.py +0 -19
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/cp949prober.py +0 -49
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/enums.py +0 -85
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/escprober.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/escsm.py +0 -261
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py +0 -196
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/euckrprober.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py +0 -388
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/euctwprober.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py +0 -284
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py +0 -316
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/jisfreq.py +0 -325
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/johabfreq.py +0 -2382
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/johabprober.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/jpcntx.py +0 -238
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py +0 -4649
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py +0 -4397
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py +0 -4380
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py +0 -4649
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py +0 -5725
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py +0 -4380
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py +0 -4380
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/latin1prober.py +0 -147
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/macromanprober.py +0 -162
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py +0 -95
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/mbcssm.py +0 -661
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py +0 -352
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/resultdict.py +0 -16
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py +0 -162
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py +0 -88
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/sjisprober.py +0 -105
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/universaldetector.py +0 -362
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/utf1632prober.py +0 -225
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/utf8prober.py +0 -82
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/chardet/version.py +0 -9
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/__init__.py +0 -7
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/ansi.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py +0 -277
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/initialise.py +0 -121
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/ansi_test.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/ansitowin32_test.py +0 -294
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/initialise_test.py +0 -189
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/isatty_test.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/utils.py +0 -49
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/tests/winterm_test.py +0 -131
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/win32.py +0 -180
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/colorama/winterm.py +0 -195
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/__init__.py +0 -33
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/compat.py +0 -1138
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/database.py +0 -1359
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/index.py +0 -508
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/locators.py +0 -1303
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/manifest.py +0 -384
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/markers.py +0 -167
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/metadata.py +0 -1068
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/resources.py +0 -358
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/scripts.py +0 -452
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/util.py +0 -2025
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/version.py +0 -751
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distlib/wheel.py +0 -1099
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distro/__init__.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distro/__main__.py +0 -4
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/distro/distro.py +0 -1399
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/__init__.py +0 -44
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/codec.py +0 -112
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/compat.py +0 -13
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/core.py +0 -400
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/idnadata.py +0 -2151
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/intranges.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/package_data.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/idna/uts46data.py +0 -8600
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/msgpack/__init__.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +0 -48
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/msgpack/ext.py +0 -193
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/msgpack/fallback.py +0 -1010
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/__about__.py +0 -26
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/__init__.py +0 -25
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +0 -301
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +0 -136
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/markers.py +0 -304
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/requirements.py +0 -146
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/specifiers.py +0 -802
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/tags.py +0 -487
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/utils.py +0 -136
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/packaging/version.py +0 -504
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +0 -3361
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +0 -566
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +0 -53
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/android.py +0 -210
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/api.py +0 -223
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/macos.py +0 -91
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/unix.py +0 -223
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/version.py +0 -4
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/platformdirs/windows.py +0 -255
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/__init__.py +0 -82
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/__main__.py +0 -17
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/cmdline.py +0 -668
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/console.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/filter.py +0 -71
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +0 -940
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatter.py +0 -124
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +0 -158
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +0 -23
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/bbcode.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/groff.py +0 -170
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/html.py +0 -989
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/img.py +0 -645
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/irc.py +0 -154
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/latex.py +0 -521
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/other.py +0 -161
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/pangomarkup.py +0 -83
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/rtf.py +0 -146
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/svg.py +0 -188
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/terminal.py +0 -127
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/formatters/terminal256.py +0 -338
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/lexer.py +0 -943
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +0 -362
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +0 -559
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +0 -1198
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/modeline.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/plugin.py +0 -88
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/regexopt.py +0 -91
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/scanner.py +0 -104
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +0 -217
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/style.py +0 -197
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/token.py +0 -213
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/unistring.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pygments/util.py +0 -330
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/__init__.py +0 -322
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/actions.py +0 -217
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/common.py +0 -432
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/core.py +0 -6115
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/diagram/__init__.py +0 -656
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/exceptions.py +0 -299
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/helpers.py +0 -1100
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/results.py +0 -796
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/testing.py +0 -331
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/unicode.py +0 -361
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyparsing/util.py +0 -284
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +0 -23
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyproject_hooks/_compat.py +0 -8
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +0 -330
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +0 -18
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +0 -353
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/__init__.py +0 -182
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/__version__.py +0 -14
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +0 -50
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/adapters.py +0 -538
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/api.py +0 -157
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/auth.py +0 -315
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/certs.py +0 -24
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/compat.py +0 -67
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/cookies.py +0 -561
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/exceptions.py +0 -141
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/help.py +0 -131
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/hooks.py +0 -33
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/models.py +0 -1034
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/packages.py +0 -16
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/sessions.py +0 -833
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/status_codes.py +0 -128
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/structures.py +0 -99
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/requests/utils.py +0 -1094
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +0 -26
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/compat/collections_abc.py +0 -6
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/providers.py +0 -133
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py +0 -547
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/resolvelib/structs.py +0 -170
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/__init__.py +0 -177
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/__main__.py +0 -274
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +0 -451
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +0 -3610
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +0 -32
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_export_format.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_extension.py +0 -10
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_fileno.py +0 -24
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_inspect.py +0 -270
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_log_render.py +0 -94
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_loop.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_null_file.py +0 -69
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_palettes.py +0 -309
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_pick.py +0 -17
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_ratio.py +0 -160
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_spinners.py +0 -482
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_stack.py +0 -16
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_timer.py +0 -19
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_win32_console.py +0 -662
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_windows.py +0 -72
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +0 -56
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/_wrap.py +0 -56
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/abc.py +0 -33
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/align.py +0 -311
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/ansi.py +0 -240
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/bar.py +0 -94
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/box.py +0 -517
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/cells.py +0 -154
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/color.py +0 -622
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/color_triplet.py +0 -38
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/columns.py +0 -187
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/console.py +0 -2633
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/constrain.py +0 -37
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/containers.py +0 -167
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/control.py +0 -225
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/default_styles.py +0 -190
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/diagnose.py +0 -37
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/emoji.py +0 -96
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/errors.py +0 -34
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/file_proxy.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/filesize.py +0 -89
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/highlighter.py +0 -232
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/json.py +0 -140
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/jupyter.py +0 -101
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/layout.py +0 -443
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/live.py +0 -375
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/live_render.py +0 -113
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/logging.py +0 -289
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/markup.py +0 -246
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/measure.py +0 -151
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/padding.py +0 -141
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/pager.py +0 -34
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/palette.py +0 -100
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/panel.py +0 -308
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/pretty.py +0 -994
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/progress.py +0 -1702
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/progress_bar.py +0 -224
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/prompt.py +0 -376
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/protocol.py +0 -42
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/region.py +0 -10
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/repr.py +0 -149
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/rule.py +0 -130
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/scope.py +0 -86
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/screen.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/segment.py +0 -739
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/spinner.py +0 -137
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/status.py +0 -132
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/style.py +0 -796
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/styled.py +0 -42
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/syntax.py +0 -948
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/table.py +0 -1002
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/text.py +0 -1307
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/theme.py +0 -115
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/themes.py +0 -5
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/traceback.py +0 -756
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/rich/tree.py +0 -251
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/six.py +0 -998
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/__init__.py +0 -608
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py +0 -94
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/_utils.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/after.py +0 -51
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/before.py +0 -46
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py +0 -71
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/nap.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/retry.py +0 -272
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/stop.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py +0 -59
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tenacity/wait.py +0 -228
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tomli/__init__.py +0 -11
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tomli/_parser.py +0 -691
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tomli/_re.py +0 -107
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/tomli/_types.py +0 -10
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/__init__.py +0 -13
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/_api.py +0 -302
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/_macos.py +0 -501
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/_openssl.py +0 -66
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +0 -31
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/truststore/_windows.py +0 -554
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/typing_extensions.py +0 -3072
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/__init__.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/_collections.py +0 -337
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/_version.py +0 -2
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/connection.py +0 -572
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +0 -1132
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +0 -36
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +0 -519
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +0 -397
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +0 -314
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +0 -130
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +0 -518
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +0 -921
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +0 -216
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +0 -323
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/fields.py +0 -274
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/filepost.py +0 -98
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +0 -51
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +0 -155
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +0 -1076
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +0 -537
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/request.py +0 -191
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/response.py +0 -879
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +0 -49
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +0 -149
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +0 -22
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/request.py +0 -137
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/response.py +0 -107
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +0 -620
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +0 -495
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +0 -159
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +0 -221
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +0 -271
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/url.py +0 -435
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +0 -152
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/webencodings/__init__.py +0 -342
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/webencodings/labels.py +0 -231
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/webencodings/mklabels.py +0 -59
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/webencodings/tests.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py +0 -325
- py2docfx/venv/template/Lib/site-packages/pkg_resources/__init__.py +0 -3715
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/data/my-test-package-source/setup.py +0 -7
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_find_distributions.py +0 -55
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_integration_zope_interface.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_markers.py +0 -8
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_pkg_resources.py +0 -432
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_resources.py +0 -869
- py2docfx/venv/template/Lib/site-packages/pkg_resources/tests/test_working_set.py +0 -501
- py2docfx/venv/template/Lib/site-packages/pygments/__init__.py +0 -82
- py2docfx/venv/template/Lib/site-packages/pygments/__main__.py +0 -17
- py2docfx/venv/template/Lib/site-packages/pygments/cmdline.py +0 -668
- py2docfx/venv/template/Lib/site-packages/pygments/console.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pygments/filter.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pygments/filters/__init__.py +0 -940
- py2docfx/venv/template/Lib/site-packages/pygments/formatter.py +0 -129
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/__init__.py +0 -157
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/_mapping.py +0 -23
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/bbcode.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/groff.py +0 -170
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/html.py +0 -987
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/img.py +0 -685
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/irc.py +0 -154
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/latex.py +0 -518
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/other.py +0 -160
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/pangomarkup.py +0 -83
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/rtf.py +0 -349
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/svg.py +0 -185
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/terminal.py +0 -127
- py2docfx/venv/template/Lib/site-packages/pygments/formatters/terminal256.py +0 -338
- py2docfx/venv/template/Lib/site-packages/pygments/lexer.py +0 -961
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/__init__.py +0 -362
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_ada_builtins.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_asy_builtins.py +0 -1644
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_cl_builtins.py +0 -231
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_cocoa_builtins.py +0 -75
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_csound_builtins.py +0 -1780
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_css_builtins.py +0 -558
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_julia_builtins.py +0 -411
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_lasso_builtins.py +0 -5326
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_lilypond_builtins.py +0 -4932
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_lua_builtins.py +0 -285
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_luau_builtins.py +0 -62
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_mapping.py +0 -589
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_mql_builtins.py +0 -1171
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_mysql_builtins.py +0 -1335
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_openedge_builtins.py +0 -2600
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_php_builtins.py +0 -3325
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_postgres_builtins.py +0 -739
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_qlik_builtins.py +0 -666
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_scheme_builtins.py +0 -1609
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_scilab_builtins.py +0 -3093
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_sourcemod_builtins.py +0 -1151
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_stan_builtins.py +0 -648
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_stata_builtins.py +0 -457
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_tsql_builtins.py +0 -1003
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_usd_builtins.py +0 -112
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_vbscript_builtins.py +0 -279
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/_vim_builtins.py +0 -1938
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/actionscript.py +0 -243
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ada.py +0 -144
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/agile.py +0 -25
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/algebra.py +0 -298
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ambient.py +0 -75
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/amdgpu.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ampl.py +0 -87
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/apdlexer.py +0 -593
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/apl.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/archetype.py +0 -315
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/arrow.py +0 -116
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/arturo.py +0 -249
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/asc.py +0 -55
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/asm.py +0 -1050
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/asn1.py +0 -178
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/automation.py +0 -379
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/bare.py +0 -101
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/basic.py +0 -656
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/bdd.py +0 -57
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/berry.py +0 -99
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/bibtex.py +0 -159
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/blueprint.py +0 -173
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/boa.py +0 -97
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/bqn.py +0 -109
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/business.py +0 -625
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/c_cpp.py +0 -414
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/c_like.py +0 -738
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/capnproto.py +0 -74
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/carbon.py +0 -95
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/cddl.py +0 -172
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/chapel.py +0 -139
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/clean.py +0 -180
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/comal.py +0 -81
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/compiled.py +0 -35
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/configs.py +0 -1424
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/console.py +0 -114
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/cplint.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/crystal.py +0 -364
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/csound.py +0 -466
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/css.py +0 -602
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/d.py +0 -259
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dalvik.py +0 -126
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/data.py +0 -763
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dax.py +0 -135
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/devicetree.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/diff.py +0 -169
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dns.py +0 -109
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dotnet.py +0 -846
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dsls.py +0 -970
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/dylan.py +0 -279
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ecl.py +0 -144
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/eiffel.py +0 -68
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/elm.py +0 -123
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/elpi.py +0 -172
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/email.py +0 -132
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/erlang.py +0 -526
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/esoteric.py +0 -300
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ezhil.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/factor.py +0 -363
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/fantom.py +0 -251
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/felix.py +0 -275
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/fift.py +0 -68
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/floscript.py +0 -81
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/forth.py +0 -178
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/fortran.py +0 -212
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/foxpro.py +0 -427
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/freefem.py +0 -893
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/func.py +0 -110
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/functional.py +0 -21
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/futhark.py +0 -105
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/gcodelexer.py +0 -35
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/gdscript.py +0 -189
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/go.py +0 -97
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/grammar_notation.py +0 -262
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/graph.py +0 -108
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/graphics.py +0 -794
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/graphql.py +0 -176
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/graphviz.py +0 -58
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/gsql.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/haskell.py +0 -866
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/haxe.py +0 -935
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/hdl.py +0 -466
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/hexdump.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/html.py +0 -626
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/idl.py +0 -284
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/igor.py +0 -435
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/inferno.py +0 -95
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/installers.py +0 -325
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/int_fiction.py +0 -1370
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/iolang.py +0 -61
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/j.py +0 -151
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/javascript.py +0 -1587
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/jmespath.py +0 -69
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/jslt.py +0 -94
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/jsonnet.py +0 -169
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/jsx.py +0 -75
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/julia.py +0 -293
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/jvm.py +0 -1802
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/kuin.py +0 -332
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/kusto.py +0 -93
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ldap.py +0 -155
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/lean.py +0 -241
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/lilypond.py +0 -225
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/lisp.py +0 -3146
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/macaulay2.py +0 -1788
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/make.py +0 -212
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/markup.py +0 -1654
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/math.py +0 -21
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/matlab.py +0 -3306
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/maxima.py +0 -84
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/meson.py +0 -139
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/mime.py +0 -210
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/minecraft.py +0 -391
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/mips.py +0 -130
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ml.py +0 -958
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/modeling.py +0 -366
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/modula2.py +0 -1579
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/mojo.py +0 -704
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/monte.py +0 -203
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/mosel.py +0 -447
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ncl.py +0 -894
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/nimrod.py +0 -199
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/nit.py +0 -63
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/nix.py +0 -144
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/oberon.py +0 -120
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/objective.py +0 -513
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ooc.py +0 -84
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/openscad.py +0 -96
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/other.py +0 -41
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/parasail.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/parsers.py +0 -798
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/pascal.py +0 -644
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/pawn.py +0 -202
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/perl.py +0 -733
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/phix.py +0 -363
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/php.py +0 -334
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/pointless.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/pony.py +0 -93
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/praat.py +0 -303
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/procfile.py +0 -41
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/prolog.py +0 -318
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/promql.py +0 -176
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/prql.py +0 -251
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ptx.py +0 -119
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/python.py +0 -1198
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/q.py +0 -187
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/qlik.py +0 -117
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/qvt.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/r.py +0 -192
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/rdf.py +0 -468
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/rebol.py +0 -419
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/resource.py +0 -83
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ride.py +0 -138
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/rita.py +0 -42
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/rnc.py +0 -66
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/roboconf.py +0 -81
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/robotframework.py +0 -551
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ruby.py +0 -518
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/rust.py +0 -222
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/sas.py +0 -227
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/savi.py +0 -171
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/scdoc.py +0 -85
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/scripting.py +0 -1598
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/sgf.py +0 -59
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/shell.py +0 -898
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/sieve.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/slash.py +0 -183
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/smalltalk.py +0 -194
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/smithy.py +0 -77
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/smv.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/snobol.py +0 -82
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/solidity.py +0 -87
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/soong.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/sophia.py +0 -102
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/special.py +0 -121
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/spice.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/sql.py +0 -1033
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/srcinfo.py +0 -62
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/stata.py +0 -170
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/supercollider.py +0 -94
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tact.py +0 -303
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tal.py +0 -77
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tcl.py +0 -148
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/teal.py +0 -88
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/templates.py +0 -2355
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/teraterm.py +0 -325
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/testing.py +0 -209
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/text.py +0 -27
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/textedit.py +0 -205
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/textfmts.py +0 -436
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/theorem.py +0 -410
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/thingsdb.py +0 -140
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tlb.py +0 -59
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tls.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/tnt.py +0 -270
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/trafficscript.py +0 -51
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/typoscript.py +0 -216
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/typst.py +0 -104
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/ul4.py +0 -309
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/unicon.py +0 -413
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/urbi.py +0 -145
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/usd.py +0 -85
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/varnish.py +0 -189
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/verification.py +0 -113
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/verifpal.py +0 -65
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/vip.py +0 -150
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/vyper.py +0 -140
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/web.py +0 -24
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/webassembly.py +0 -119
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/webidl.py +0 -298
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/webmisc.py +0 -1006
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/wgsl.py +0 -406
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/whiley.py +0 -115
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/wowtoc.py +0 -120
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/wren.py +0 -98
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/x10.py +0 -66
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/xorg.py +0 -38
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/yang.py +0 -103
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/yara.py +0 -69
- py2docfx/venv/template/Lib/site-packages/pygments/lexers/zig.py +0 -125
- py2docfx/venv/template/Lib/site-packages/pygments/modeline.py +0 -43
- py2docfx/venv/template/Lib/site-packages/pygments/plugin.py +0 -72
- py2docfx/venv/template/Lib/site-packages/pygments/regexopt.py +0 -91
- py2docfx/venv/template/Lib/site-packages/pygments/scanner.py +0 -104
- py2docfx/venv/template/Lib/site-packages/pygments/sphinxext.py +0 -247
- py2docfx/venv/template/Lib/site-packages/pygments/style.py +0 -203
- py2docfx/venv/template/Lib/site-packages/pygments/styles/__init__.py +0 -61
- py2docfx/venv/template/Lib/site-packages/pygments/styles/_mapping.py +0 -54
- py2docfx/venv/template/Lib/site-packages/pygments/styles/abap.py +0 -32
- py2docfx/venv/template/Lib/site-packages/pygments/styles/algol.py +0 -65
- py2docfx/venv/template/Lib/site-packages/pygments/styles/algol_nu.py +0 -65
- py2docfx/venv/template/Lib/site-packages/pygments/styles/arduino.py +0 -100
- py2docfx/venv/template/Lib/site-packages/pygments/styles/autumn.py +0 -67
- py2docfx/venv/template/Lib/site-packages/pygments/styles/borland.py +0 -53
- py2docfx/venv/template/Lib/site-packages/pygments/styles/bw.py +0 -52
- py2docfx/venv/template/Lib/site-packages/pygments/styles/coffee.py +0 -80
- py2docfx/venv/template/Lib/site-packages/pygments/styles/colorful.py +0 -83
- py2docfx/venv/template/Lib/site-packages/pygments/styles/default.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pygments/styles/dracula.py +0 -90
- py2docfx/venv/template/Lib/site-packages/pygments/styles/emacs.py +0 -75
- py2docfx/venv/template/Lib/site-packages/pygments/styles/friendly.py +0 -76
- py2docfx/venv/template/Lib/site-packages/pygments/styles/friendly_grayscale.py +0 -80
- py2docfx/venv/template/Lib/site-packages/pygments/styles/fruity.py +0 -47
- py2docfx/venv/template/Lib/site-packages/pygments/styles/gh_dark.py +0 -113
- py2docfx/venv/template/Lib/site-packages/pygments/styles/gruvbox.py +0 -118
- py2docfx/venv/template/Lib/site-packages/pygments/styles/igor.py +0 -32
- py2docfx/venv/template/Lib/site-packages/pygments/styles/inkpot.py +0 -72
- py2docfx/venv/template/Lib/site-packages/pygments/styles/lightbulb.py +0 -110
- py2docfx/venv/template/Lib/site-packages/pygments/styles/lilypond.py +0 -62
- py2docfx/venv/template/Lib/site-packages/pygments/styles/lovelace.py +0 -100
- py2docfx/venv/template/Lib/site-packages/pygments/styles/manni.py +0 -79
- py2docfx/venv/template/Lib/site-packages/pygments/styles/material.py +0 -124
- py2docfx/venv/template/Lib/site-packages/pygments/styles/monokai.py +0 -112
- py2docfx/venv/template/Lib/site-packages/pygments/styles/murphy.py +0 -82
- py2docfx/venv/template/Lib/site-packages/pygments/styles/native.py +0 -70
- py2docfx/venv/template/Lib/site-packages/pygments/styles/nord.py +0 -156
- py2docfx/venv/template/Lib/site-packages/pygments/styles/onedark.py +0 -63
- py2docfx/venv/template/Lib/site-packages/pygments/styles/paraiso_dark.py +0 -124
- py2docfx/venv/template/Lib/site-packages/pygments/styles/paraiso_light.py +0 -124
- py2docfx/venv/template/Lib/site-packages/pygments/styles/pastie.py +0 -78
- py2docfx/venv/template/Lib/site-packages/pygments/styles/perldoc.py +0 -73
- py2docfx/venv/template/Lib/site-packages/pygments/styles/rainbow_dash.py +0 -95
- py2docfx/venv/template/Lib/site-packages/pygments/styles/rrt.py +0 -39
- py2docfx/venv/template/Lib/site-packages/pygments/styles/sas.py +0 -46
- py2docfx/venv/template/Lib/site-packages/pygments/styles/solarized.py +0 -144
- py2docfx/venv/template/Lib/site-packages/pygments/styles/staroffice.py +0 -31
- py2docfx/venv/template/Lib/site-packages/pygments/styles/stata_dark.py +0 -42
- py2docfx/venv/template/Lib/site-packages/pygments/styles/stata_light.py +0 -42
- py2docfx/venv/template/Lib/site-packages/pygments/styles/tango.py +0 -143
- py2docfx/venv/template/Lib/site-packages/pygments/styles/trac.py +0 -66
- py2docfx/venv/template/Lib/site-packages/pygments/styles/vim.py +0 -67
- py2docfx/venv/template/Lib/site-packages/pygments/styles/vs.py +0 -41
- py2docfx/venv/template/Lib/site-packages/pygments/styles/xcode.py +0 -53
- py2docfx/venv/template/Lib/site-packages/pygments/styles/zenburn.py +0 -83
- py2docfx/venv/template/Lib/site-packages/pygments/token.py +0 -214
- py2docfx/venv/template/Lib/site-packages/pygments/unistring.py +0 -153
- py2docfx/venv/template/Lib/site-packages/pygments/util.py +0 -324
- py2docfx/venv/template/Lib/site-packages/requests/__init__.py +0 -184
- py2docfx/venv/template/Lib/site-packages/requests/__version__.py +0 -14
- py2docfx/venv/template/Lib/site-packages/requests/_internal_utils.py +0 -50
- py2docfx/venv/template/Lib/site-packages/requests/adapters.py +0 -719
- py2docfx/venv/template/Lib/site-packages/requests/api.py +0 -157
- py2docfx/venv/template/Lib/site-packages/requests/auth.py +0 -314
- py2docfx/venv/template/Lib/site-packages/requests/certs.py +0 -17
- py2docfx/venv/template/Lib/site-packages/requests/compat.py +0 -94
- py2docfx/venv/template/Lib/site-packages/requests/cookies.py +0 -561
- py2docfx/venv/template/Lib/site-packages/requests/exceptions.py +0 -151
- py2docfx/venv/template/Lib/site-packages/requests/help.py +0 -134
- py2docfx/venv/template/Lib/site-packages/requests/hooks.py +0 -33
- py2docfx/venv/template/Lib/site-packages/requests/models.py +0 -1037
- py2docfx/venv/template/Lib/site-packages/requests/packages.py +0 -23
- py2docfx/venv/template/Lib/site-packages/requests/sessions.py +0 -831
- py2docfx/venv/template/Lib/site-packages/requests/status_codes.py +0 -128
- py2docfx/venv/template/Lib/site-packages/requests/structures.py +0 -99
- py2docfx/venv/template/Lib/site-packages/requests/utils.py +0 -1096
- py2docfx/venv/template/Lib/site-packages/setuptools/__init__.py +0 -259
- py2docfx/venv/template/Lib/site-packages/setuptools/_core_metadata.py +0 -285
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/__init__.py +0 -14
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_collections.py +0 -58
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_functools.py +0 -73
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_itertools.py +0 -52
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_log.py +0 -3
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_macos_compat.py +0 -12
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_modified.py +0 -72
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_msvccompiler.py +0 -568
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_elffile.py +0 -108
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_manylinux.py +0 -260
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_musllinux.py +0 -83
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_parser.py +0 -356
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/_tokenizer.py +0 -192
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/markers.py +0 -252
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/metadata.py +0 -825
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/requirements.py +0 -90
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/specifiers.py +0 -1017
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/tags.py +0 -571
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/utils.py +0 -172
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/_vendor/packaging/version.py +0 -563
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/archive_util.py +0 -283
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/bcppcompiler.py +0 -396
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/ccompiler.py +0 -1255
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/cmd.py +0 -439
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/__init__.py +0 -25
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/_framework_compat.py +0 -54
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/bdist.py +0 -155
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/bdist_dumb.py +0 -140
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/bdist_rpm.py +0 -597
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/build.py +0 -156
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/build_clib.py +0 -208
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/build_ext.py +0 -797
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/build_py.py +0 -406
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/build_scripts.py +0 -170
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/check.py +0 -154
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/clean.py +0 -76
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/config.py +0 -369
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install.py +0 -810
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install_data.py +0 -94
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install_egg_info.py +0 -92
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install_headers.py +0 -44
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install_lib.py +0 -234
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/install_scripts.py +0 -61
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/register.py +0 -322
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/sdist.py +0 -527
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/command/upload.py +0 -208
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/compat/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/compat/py38.py +0 -34
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/compat/py39.py +0 -66
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/config.py +0 -151
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/core.py +0 -287
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/cygwinccompiler.py +0 -334
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/debug.py +0 -5
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/dep_util.py +0 -14
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/dir_util.py +0 -238
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/dist.py +0 -1298
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/errors.py +0 -127
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/extension.py +0 -247
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/fancy_getopt.py +0 -469
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/file_util.py +0 -235
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/filelist.py +0 -369
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/log.py +0 -56
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/msvc9compiler.py +0 -822
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/msvccompiler.py +0 -687
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/spawn.py +0 -117
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/sysconfig.py +0 -582
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/__init__.py +0 -42
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/compat/py38.py +0 -50
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/support.py +0 -134
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_archive_util.py +0 -386
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_bdist.py +0 -47
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_bdist_dumb.py +0 -78
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_bdist_rpm.py +0 -128
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_build.py +0 -47
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_build_clib.py +0 -134
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_build_ext.py +0 -563
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_build_py.py +0 -196
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_build_scripts.py +0 -96
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_ccompiler.py +0 -91
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_check.py +0 -194
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_clean.py +0 -45
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_cmd.py +0 -107
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_config.py +0 -116
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_config_cmd.py +0 -87
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_core.py +0 -130
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_cygwinccompiler.py +0 -81
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_dir_util.py +0 -112
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_dist.py +0 -545
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_extension.py +0 -108
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_file_util.py +0 -94
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_filelist.py +0 -336
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_install.py +0 -245
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_install_data.py +0 -74
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_install_headers.py +0 -33
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_install_lib.py +0 -110
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_install_scripts.py +0 -52
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_log.py +0 -12
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_mingwccompiler.py +0 -56
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_modified.py +0 -119
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_msvc9compiler.py +0 -184
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_msvccompiler.py +0 -114
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_register.py +0 -314
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_sdist.py +0 -479
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_spawn.py +0 -131
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_sysconfig.py +0 -319
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_text_file.py +0 -127
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_unixccompiler.py +0 -351
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_upload.py +0 -215
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_util.py +0 -243
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_version.py +0 -80
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/test_versionpredicate.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/tests/unix_compat.py +0 -17
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/text_file.py +0 -286
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/unixccompiler.py +0 -402
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/util.py +0 -504
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/version.py +0 -349
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/versionpredicate.py +0 -175
- py2docfx/venv/template/Lib/site-packages/setuptools/_distutils/zosccompiler.py +0 -229
- py2docfx/venv/template/Lib/site-packages/setuptools/_entry_points.py +0 -89
- py2docfx/venv/template/Lib/site-packages/setuptools/_imp.py +0 -89
- py2docfx/venv/template/Lib/site-packages/setuptools/_importlib.py +0 -13
- py2docfx/venv/template/Lib/site-packages/setuptools/_itertools.py +0 -23
- py2docfx/venv/template/Lib/site-packages/setuptools/_normalization.py +0 -144
- py2docfx/venv/template/Lib/site-packages/setuptools/_path.py +0 -82
- py2docfx/venv/template/Lib/site-packages/setuptools/_reqs.py +0 -38
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/__init__.py +0 -27
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/autoasync.py +0 -142
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/autocommand.py +0 -70
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/automain.py +0 -59
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/autoparse.py +0 -333
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/autocommand/errors.py +0 -23
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/backports/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/backports/tarfile/__init__.py +0 -2937
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/backports/tarfile/__main__.py +0 -5
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/backports/tarfile/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/backports/tarfile/compat/py38.py +0 -24
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/__init__.py +0 -1083
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_adapters.py +0 -83
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_collections.py +0 -30
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_compat.py +0 -57
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_functools.py +0 -104
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_itertools.py +0 -73
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_meta.py +0 -67
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/_text.py +0 -99
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/compat/py311.py +0 -22
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/compat/py39.py +0 -36
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_metadata/diagnose.py +0 -21
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/__init__.py +0 -36
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/_adapters.py +0 -168
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/_common.py +0 -210
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/_itertools.py +0 -38
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/abc.py +0 -171
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/compat/py38.py +0 -11
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/compat/py39.py +0 -10
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/functional.py +0 -81
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/future/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/future/adapters.py +0 -95
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/readers.py +0 -194
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/simple.py +0 -106
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/_path.py +0 -56
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/compat/py312.py +0 -18
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/compat/py39.py +0 -10
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/data01/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/data01/subdirectory/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/data02/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/data02/one/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/data02/two/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_compatibilty_files.py +0 -104
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_contents.py +0 -43
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_custom.py +0 -47
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_files.py +0 -117
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_functional.py +0 -242
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_open.py +0 -89
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_path.py +0 -65
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_read.py +0 -97
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_reader.py +0 -145
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/test_resource.py +0 -241
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/util.py +0 -164
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/importlib_resources/tests/zip.py +0 -32
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/inflect/__init__.py +0 -3986
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/inflect/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/inflect/compat/py38.py +0 -7
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/context.py +0 -361
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/functools/__init__.py +0 -633
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/__init__.py +0 -624
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/layouts.py +0 -25
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/show-newlines.py +0 -33
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/strip-prefix.py +0 -21
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/to-dvorak.py +0 -6
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/jaraco/text/to-qwerty.py +0 -6
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/more_itertools/__init__.py +0 -6
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/more_itertools/more.py +0 -4806
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/more_itertools/recipes.py +0 -1046
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/ordered_set/__init__.py +0 -536
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_elffile.py +0 -110
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_manylinux.py +0 -262
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_musllinux.py +0 -85
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_parser.py +0 -354
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/_tokenizer.py +0 -194
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/markers.py +0 -325
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/metadata.py +0 -804
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/requirements.py +0 -91
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/specifiers.py +0 -1009
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/tags.py +0 -568
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/utils.py +0 -174
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/packaging/version.py +0 -563
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/__init__.py +0 -627
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/__main__.py +0 -55
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/android.py +0 -249
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/api.py +0 -292
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/macos.py +0 -130
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/unix.py +0 -275
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/version.py +0 -16
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/platformdirs/windows.py +0 -272
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/tomli/__init__.py +0 -11
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/tomli/_parser.py +0 -691
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/tomli/_re.py +0 -107
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/tomli/_types.py +0 -10
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/__init__.py +0 -48
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_checkers.py +0 -993
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_config.py +0 -108
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_decorators.py +0 -235
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_exceptions.py +0 -42
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_functions.py +0 -308
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_importhook.py +0 -213
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_memo.py +0 -48
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_pytest_plugin.py +0 -127
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_suppression.py +0 -86
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_transformer.py +0 -1229
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_union_transformer.py +0 -55
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typeguard/_utils.py +0 -173
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/typing_extensions.py +0 -3641
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/__init__.py +0 -3
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/__main__.py +0 -23
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/_setuptools_logging.py +0 -26
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/bdist_wheel.py +0 -595
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/cli/__init__.py +0 -155
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/cli/convert.py +0 -273
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/cli/pack.py +0 -85
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/cli/tags.py +0 -139
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/cli/unpack.py +0 -30
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/macosx_libfile.py +0 -469
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/metadata.py +0 -180
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/util.py +0 -26
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_elffile.py +0 -108
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_manylinux.py +0 -260
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_musllinux.py +0 -83
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_parser.py +0 -356
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/_tokenizer.py +0 -192
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/markers.py +0 -253
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/requirements.py +0 -90
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/specifiers.py +0 -1011
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/tags.py +0 -571
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/utils.py +0 -172
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/vendored/packaging/version.py +0 -561
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/wheel/wheelfile.py +0 -196
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/zipp/__init__.py +0 -501
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/zipp/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/zipp/compat/py310.py +0 -11
- py2docfx/venv/template/Lib/site-packages/setuptools/_vendor/zipp/glob.py +0 -106
- py2docfx/venv/template/Lib/site-packages/setuptools/archive_util.py +0 -216
- py2docfx/venv/template/Lib/site-packages/setuptools/build_meta.py +0 -524
- py2docfx/venv/template/Lib/site-packages/setuptools/command/__init__.py +0 -12
- py2docfx/venv/template/Lib/site-packages/setuptools/command/_requirestxt.py +0 -131
- py2docfx/venv/template/Lib/site-packages/setuptools/command/alias.py +0 -78
- py2docfx/venv/template/Lib/site-packages/setuptools/command/bdist_egg.py +0 -464
- py2docfx/venv/template/Lib/site-packages/setuptools/command/bdist_rpm.py +0 -39
- py2docfx/venv/template/Lib/site-packages/setuptools/command/bdist_wheel.py +0 -597
- py2docfx/venv/template/Lib/site-packages/setuptools/command/build.py +0 -124
- py2docfx/venv/template/Lib/site-packages/setuptools/command/build_clib.py +0 -104
- py2docfx/venv/template/Lib/site-packages/setuptools/command/build_ext.py +0 -459
- py2docfx/venv/template/Lib/site-packages/setuptools/command/build_py.py +0 -401
- py2docfx/venv/template/Lib/site-packages/setuptools/command/develop.py +0 -196
- py2docfx/venv/template/Lib/site-packages/setuptools/command/dist_info.py +0 -106
- py2docfx/venv/template/Lib/site-packages/setuptools/command/easy_install.py +0 -2362
- py2docfx/venv/template/Lib/site-packages/setuptools/command/editable_wheel.py +0 -915
- py2docfx/venv/template/Lib/site-packages/setuptools/command/egg_info.py +0 -726
- py2docfx/venv/template/Lib/site-packages/setuptools/command/install.py +0 -160
- py2docfx/venv/template/Lib/site-packages/setuptools/command/install_egg_info.py +0 -57
- py2docfx/venv/template/Lib/site-packages/setuptools/command/install_lib.py +0 -127
- py2docfx/venv/template/Lib/site-packages/setuptools/command/install_scripts.py +0 -68
- py2docfx/venv/template/Lib/site-packages/setuptools/command/register.py +0 -18
- py2docfx/venv/template/Lib/site-packages/setuptools/command/rotate.py +0 -64
- py2docfx/venv/template/Lib/site-packages/setuptools/command/saveopts.py +0 -21
- py2docfx/venv/template/Lib/site-packages/setuptools/command/sdist.py +0 -204
- py2docfx/venv/template/Lib/site-packages/setuptools/command/setopt.py +0 -140
- py2docfx/venv/template/Lib/site-packages/setuptools/command/test.py +0 -42
- py2docfx/venv/template/Lib/site-packages/setuptools/command/upload.py +0 -17
- py2docfx/venv/template/Lib/site-packages/setuptools/command/upload_docs.py +0 -221
- py2docfx/venv/template/Lib/site-packages/setuptools/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/compat/py310.py +0 -10
- py2docfx/venv/template/Lib/site-packages/setuptools/compat/py311.py +0 -26
- py2docfx/venv/template/Lib/site-packages/setuptools/compat/py39.py +0 -9
- py2docfx/venv/template/Lib/site-packages/setuptools/config/__init__.py +0 -43
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_apply_pyprojecttoml.py +0 -436
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/__init__.py +0 -34
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/error_reporting.py +0 -338
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/extra_validations.py +0 -52
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/fastjsonschema_exceptions.py +0 -51
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/fastjsonschema_validations.py +0 -1104
- py2docfx/venv/template/Lib/site-packages/setuptools/config/_validate_pyproject/formats.py +0 -354
- py2docfx/venv/template/Lib/site-packages/setuptools/config/expand.py +0 -443
- py2docfx/venv/template/Lib/site-packages/setuptools/config/pyprojecttoml.py +0 -453
- py2docfx/venv/template/Lib/site-packages/setuptools/config/setupcfg.py +0 -777
- py2docfx/venv/template/Lib/site-packages/setuptools/depends.py +0 -167
- py2docfx/venv/template/Lib/site-packages/setuptools/discovery.py +0 -611
- py2docfx/venv/template/Lib/site-packages/setuptools/dist.py +0 -950
- py2docfx/venv/template/Lib/site-packages/setuptools/errors.py +0 -66
- py2docfx/venv/template/Lib/site-packages/setuptools/extension.py +0 -151
- py2docfx/venv/template/Lib/site-packages/setuptools/glob.py +0 -165
- py2docfx/venv/template/Lib/site-packages/setuptools/installer.py +0 -144
- py2docfx/venv/template/Lib/site-packages/setuptools/launch.py +0 -36
- py2docfx/venv/template/Lib/site-packages/setuptools/logging.py +0 -38
- py2docfx/venv/template/Lib/site-packages/setuptools/modified.py +0 -8
- py2docfx/venv/template/Lib/site-packages/setuptools/monkey.py +0 -157
- py2docfx/venv/template/Lib/site-packages/setuptools/msvc.py +0 -1747
- py2docfx/venv/template/Lib/site-packages/setuptools/namespaces.py +0 -105
- py2docfx/venv/template/Lib/site-packages/setuptools/package_index.py +0 -1148
- py2docfx/venv/template/Lib/site-packages/setuptools/sandbox.py +0 -530
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/__init__.py +0 -15
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/compat/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/compat/py39.py +0 -4
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/downloads/__init__.py +0 -57
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/downloads/preload.py +0 -19
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/test_apply_pyprojecttoml.py +0 -466
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/test_expand.py +0 -220
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/test_pyprojecttoml.py +0 -397
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/test_pyprojecttoml_dynamic_deps.py +0 -99
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/config/test_setupcfg.py +0 -967
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/contexts.py +0 -145
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/environment.py +0 -95
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/fixtures.py +0 -157
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/integration/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/integration/helpers.py +0 -77
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/integration/test_pip_install_sdist.py +0 -225
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/mod_with_constant.py +0 -1
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/namespaces.py +0 -90
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/script-with-bom.py +0 -1
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/server.py +0 -86
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_archive_util.py +0 -36
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_bdist_deprecations.py +0 -28
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_bdist_egg.py +0 -69
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_bdist_wheel.py +0 -611
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_build.py +0 -33
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_build_clib.py +0 -83
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_build_ext.py +0 -292
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_build_meta.py +0 -973
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_build_py.py +0 -480
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_config_discovery.py +0 -643
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_core_metadata.py +0 -391
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_depends.py +0 -15
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_develop.py +0 -175
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_dist.py +0 -281
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_dist_info.py +0 -210
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_distutils_adoption.py +0 -160
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_easy_install.py +0 -1458
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_editable_install.py +0 -1285
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_egg_info.py +0 -1290
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_extern.py +0 -20
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_find_packages.py +0 -219
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_find_py_modules.py +0 -73
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_glob.py +0 -45
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_install_scripts.py +0 -88
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_integration.py +0 -122
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_logging.py +0 -74
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_manifest.py +0 -631
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_msvc14.py +0 -83
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_namespaces.py +0 -138
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_packageindex.py +0 -277
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_register.py +0 -19
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_sandbox.py +0 -134
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_sdist.py +0 -910
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_setopt.py +0 -40
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_setuptools.py +0 -289
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_unicode_utils.py +0 -10
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_upload.py +0 -19
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_virtualenv.py +0 -115
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_warnings.py +0 -107
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_wheel.py +0 -707
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/test_windows_wrappers.py +0 -259
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/text.py +0 -4
- py2docfx/venv/template/Lib/site-packages/setuptools/tests/textwrap.py +0 -6
- py2docfx/venv/template/Lib/site-packages/setuptools/unicode_utils.py +0 -102
- py2docfx/venv/template/Lib/site-packages/setuptools/version.py +0 -6
- py2docfx/venv/template/Lib/site-packages/setuptools/warnings.py +0 -107
- py2docfx/venv/template/Lib/site-packages/setuptools/wheel.py +0 -237
- py2docfx/venv/template/Lib/site-packages/setuptools/windows_support.py +0 -30
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/__init__.py +0 -83
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/among.py +0 -13
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/arabic_stemmer.py +0 -1199
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/armenian_stemmer.py +0 -316
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/basestemmer.py +0 -323
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/basque_stemmer.py +0 -683
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/catalan_stemmer.py +0 -784
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/danish_stemmer.py +0 -221
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/dutch_stemmer.py +0 -468
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/english_stemmer.py +0 -731
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/finnish_stemmer.py +0 -548
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/french_stemmer.py +0 -967
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/german_stemmer.py +0 -415
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/greek_stemmer.py +0 -2271
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/hindi_stemmer.py +0 -173
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/hungarian_stemmer.py +0 -520
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/indonesian_stemmer.py +0 -319
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/irish_stemmer.py +0 -276
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/italian_stemmer.py +0 -715
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/lithuanian_stemmer.py +0 -469
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/nepali_stemmer.py +0 -274
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/norwegian_stemmer.py +0 -191
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/porter_stemmer.py +0 -506
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/portuguese_stemmer.py +0 -659
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/romanian_stemmer.py +0 -633
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/russian_stemmer.py +0 -492
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/serbian_stemmer.py +0 -3497
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/spanish_stemmer.py +0 -708
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/swedish_stemmer.py +0 -189
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/tamil_stemmer.py +0 -1788
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/turkish_stemmer.py +0 -1803
- py2docfx/venv/template/Lib/site-packages/snowballstemmer/yiddish_stemmer.py +0 -855
- py2docfx/venv/template/Lib/site-packages/sphinx/__init__.py +0 -54
- py2docfx/venv/template/Lib/site-packages/sphinx/__main__.py +0 -5
- py2docfx/venv/template/Lib/site-packages/sphinx/addnodes.py +0 -564
- py2docfx/venv/template/Lib/site-packages/sphinx/application.py +0 -1344
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/__init__.py +0 -671
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/_epub_base.py +0 -708
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/changes.py +0 -159
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/dirhtml.py +0 -51
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/dummy.py +0 -46
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/epub3.py +0 -293
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/gettext.py +0 -306
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/html/__init__.py +0 -1419
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/html/transforms.py +0 -84
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/__init__.py +0 -546
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/constants.py +0 -210
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/nodes.py +0 -37
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/theming.py +0 -132
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/transforms.py +0 -632
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/latex/util.py +0 -48
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/linkcheck.py +0 -598
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/manpage.py +0 -125
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/singlehtml.py +0 -194
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/texinfo.py +0 -224
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/text.py +0 -89
- py2docfx/venv/template/Lib/site-packages/sphinx/builders/xml.py +0 -117
- py2docfx/venv/template/Lib/site-packages/sphinx/cmd/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/sphinx/cmd/build.py +0 -324
- py2docfx/venv/template/Lib/site-packages/sphinx/cmd/make_mode.py +0 -161
- py2docfx/venv/template/Lib/site-packages/sphinx/cmd/quickstart.py +0 -609
- py2docfx/venv/template/Lib/site-packages/sphinx/config.py +0 -520
- py2docfx/venv/template/Lib/site-packages/sphinx/deprecation.py +0 -83
- py2docfx/venv/template/Lib/site-packages/sphinx/directives/__init__.py +0 -340
- py2docfx/venv/template/Lib/site-packages/sphinx/directives/code.py +0 -483
- py2docfx/venv/template/Lib/site-packages/sphinx/directives/other.py +0 -393
- py2docfx/venv/template/Lib/site-packages/sphinx/directives/patches.py +0 -189
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/__init__.py +0 -403
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/c.py +0 -3880
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/changeset.py +0 -160
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/citation.py +0 -153
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/cpp.py +0 -8162
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/index.py +0 -122
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/javascript.py +0 -499
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/math.py +0 -150
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/python.py +0 -1521
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/rst.py +0 -303
- py2docfx/venv/template/Lib/site-packages/sphinx/domains/std.py +0 -1155
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/__init__.py +0 -730
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/adapters/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/adapters/asset.py +0 -15
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/adapters/indexentries.py +0 -172
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/adapters/toctree.py +0 -340
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/__init__.py +0 -73
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/asset.py +0 -141
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/dependencies.py +0 -54
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/metadata.py +0 -68
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/title.py +0 -59
- py2docfx/venv/template/Lib/site-packages/sphinx/environment/collectors/toctree.py +0 -350
- py2docfx/venv/template/Lib/site-packages/sphinx/errors.py +0 -127
- py2docfx/venv/template/Lib/site-packages/sphinx/events.py +0 -120
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/apidoc.py +0 -470
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/__init__.py +0 -2793
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/directive.py +0 -148
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/importer.py +0 -307
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/mock.py +0 -195
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/preserve_defaults.py +0 -124
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/type_comment.py +0 -131
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autodoc/typehints.py +0 -216
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autosectionlabel.py +0 -66
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autosummary/__init__.py +0 -837
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/autosummary/generate.py +0 -646
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/coverage.py +0 -315
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/doctest.py +0 -561
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/duration.py +0 -90
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/extlinks.py +0 -120
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/githubpages.py +0 -31
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/graphviz.py +0 -416
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/ifconfig.py +0 -78
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/imgconverter.py +0 -92
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/imgmath.py +0 -390
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/inheritance_diagram.py +0 -474
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/intersphinx.py +0 -684
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/linkcode.py +0 -73
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/mathjax.py +0 -122
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/napoleon/__init__.py +0 -474
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/napoleon/docstring.py +0 -1356
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/napoleon/iterators.py +0 -235
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/todo.py +0 -243
- py2docfx/venv/template/Lib/site-packages/sphinx/ext/viewcode.py +0 -341
- py2docfx/venv/template/Lib/site-packages/sphinx/extension.py +0 -82
- py2docfx/venv/template/Lib/site-packages/sphinx/highlighting.py +0 -184
- py2docfx/venv/template/Lib/site-packages/sphinx/io.py +0 -221
- py2docfx/venv/template/Lib/site-packages/sphinx/jinja2glue.py +0 -217
- py2docfx/venv/template/Lib/site-packages/sphinx/locale/__init__.py +0 -261
- py2docfx/venv/template/Lib/site-packages/sphinx/parsers.py +0 -96
- py2docfx/venv/template/Lib/site-packages/sphinx/project.py +0 -94
- py2docfx/venv/template/Lib/site-packages/sphinx/pycode/__init__.py +0 -171
- py2docfx/venv/template/Lib/site-packages/sphinx/pycode/ast.py +0 -211
- py2docfx/venv/template/Lib/site-packages/sphinx/pycode/parser.py +0 -573
- py2docfx/venv/template/Lib/site-packages/sphinx/pygments_styles.py +0 -87
- py2docfx/venv/template/Lib/site-packages/sphinx/registry.py +0 -513
- py2docfx/venv/template/Lib/site-packages/sphinx/roles.py +0 -428
- py2docfx/venv/template/Lib/site-packages/sphinx/search/__init__.py +0 -593
- py2docfx/venv/template/Lib/site-packages/sphinx/search/da.py +0 -120
- py2docfx/venv/template/Lib/site-packages/sphinx/search/de.py +0 -303
- py2docfx/venv/template/Lib/site-packages/sphinx/search/en.py +0 -220
- py2docfx/venv/template/Lib/site-packages/sphinx/search/es.py +0 -363
- py2docfx/venv/template/Lib/site-packages/sphinx/search/fi.py +0 -113
- py2docfx/venv/template/Lib/site-packages/sphinx/search/fr.py +0 -199
- py2docfx/venv/template/Lib/site-packages/sphinx/search/hu.py +0 -226
- py2docfx/venv/template/Lib/site-packages/sphinx/search/it.py +0 -316
- py2docfx/venv/template/Lib/site-packages/sphinx/search/ja.py +0 -536
- py2docfx/venv/template/Lib/site-packages/sphinx/search/nl.py +0 -127
- py2docfx/venv/template/Lib/site-packages/sphinx/search/no.py +0 -202
- py2docfx/venv/template/Lib/site-packages/sphinx/search/pt.py +0 -261
- py2docfx/venv/template/Lib/site-packages/sphinx/search/ro.py +0 -22
- py2docfx/venv/template/Lib/site-packages/sphinx/search/ru.py +0 -251
- py2docfx/venv/template/Lib/site-packages/sphinx/search/sv.py +0 -140
- py2docfx/venv/template/Lib/site-packages/sphinx/search/tr.py +0 -22
- py2docfx/venv/template/Lib/site-packages/sphinx/search/zh.py +0 -262
- py2docfx/venv/template/Lib/site-packages/sphinx/setup_command.py +0 -192
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/__init__.py +0 -7
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/comparer.py +0 -97
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/fixtures.py +0 -250
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/path.py +0 -210
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/restructuredtext.py +0 -27
- py2docfx/venv/template/Lib/site-packages/sphinx/testing/util.py +0 -206
- py2docfx/venv/template/Lib/site-packages/sphinx/theming.py +0 -230
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/__init__.py +0 -419
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/compact_bullet_list.py +0 -88
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/i18n.py +0 -528
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/post_transforms/__init__.py +0 -279
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/post_transforms/code.py +0 -136
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/post_transforms/images.py +0 -271
- py2docfx/venv/template/Lib/site-packages/sphinx/transforms/references.py +0 -47
- py2docfx/venv/template/Lib/site-packages/sphinx/util/__init__.py +0 -407
- py2docfx/venv/template/Lib/site-packages/sphinx/util/build_phase.py +0 -12
- py2docfx/venv/template/Lib/site-packages/sphinx/util/cfamily.py +0 -462
- py2docfx/venv/template/Lib/site-packages/sphinx/util/console.py +0 -129
- py2docfx/venv/template/Lib/site-packages/sphinx/util/display.py +0 -87
- py2docfx/venv/template/Lib/site-packages/sphinx/util/docfields.py +0 -368
- py2docfx/venv/template/Lib/site-packages/sphinx/util/docstrings.py +0 -88
- py2docfx/venv/template/Lib/site-packages/sphinx/util/docutils.py +0 -621
- py2docfx/venv/template/Lib/site-packages/sphinx/util/exceptions.py +0 -67
- py2docfx/venv/template/Lib/site-packages/sphinx/util/fileutil.py +0 -97
- py2docfx/venv/template/Lib/site-packages/sphinx/util/http_date.py +0 -20
- py2docfx/venv/template/Lib/site-packages/sphinx/util/i18n.py +0 -262
- py2docfx/venv/template/Lib/site-packages/sphinx/util/images.py +0 -113
- py2docfx/venv/template/Lib/site-packages/sphinx/util/inspect.py +0 -811
- py2docfx/venv/template/Lib/site-packages/sphinx/util/inventory.py +0 -170
- py2docfx/venv/template/Lib/site-packages/sphinx/util/jsdump.py +0 -201
- py2docfx/venv/template/Lib/site-packages/sphinx/util/logging.py +0 -603
- py2docfx/venv/template/Lib/site-packages/sphinx/util/matching.py +0 -166
- py2docfx/venv/template/Lib/site-packages/sphinx/util/math.py +0 -58
- py2docfx/venv/template/Lib/site-packages/sphinx/util/nodes.py +0 -629
- py2docfx/venv/template/Lib/site-packages/sphinx/util/osutil.py +0 -221
- py2docfx/venv/template/Lib/site-packages/sphinx/util/parallel.py +0 -151
- py2docfx/venv/template/Lib/site-packages/sphinx/util/png.py +0 -43
- py2docfx/venv/template/Lib/site-packages/sphinx/util/requests.py +0 -92
- py2docfx/venv/template/Lib/site-packages/sphinx/util/rst.py +0 -110
- py2docfx/venv/template/Lib/site-packages/sphinx/util/stemmer/__init__.py +0 -62
- py2docfx/venv/template/Lib/site-packages/sphinx/util/tags.py +0 -81
- py2docfx/venv/template/Lib/site-packages/sphinx/util/template.py +0 -132
- py2docfx/venv/template/Lib/site-packages/sphinx/util/texescape.py +0 -153
- py2docfx/venv/template/Lib/site-packages/sphinx/util/typing.py +0 -352
- py2docfx/venv/template/Lib/site-packages/sphinx/versioning.py +0 -176
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/__init__.py +0 -1
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/_html4.py +0 -858
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/html.py +0 -45
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/html5.py +0 -824
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/latex.py +0 -2116
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/manpage.py +0 -459
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/texinfo.py +0 -1562
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/text.py +0 -1182
- py2docfx/venv/template/Lib/site-packages/sphinx/writers/xml.py +0 -49
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/applehelp/__init__.py +0 -276
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/devhelp/__init__.py +0 -143
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/htmlhelp/__init__.py +0 -340
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/jsmath/__init__.py +0 -92
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/jsmath/version.py +0 -11
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/qthelp/__init__.py +0 -266
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/serializinghtml/__init__.py +0 -180
- py2docfx/venv/template/Lib/site-packages/sphinxcontrib/serializinghtml/jsonimpl.py +0 -33
- py2docfx/venv/template/Lib/site-packages/urllib3/__init__.py +0 -211
- py2docfx/venv/template/Lib/site-packages/urllib3/_base_connection.py +0 -172
- py2docfx/venv/template/Lib/site-packages/urllib3/_collections.py +0 -483
- py2docfx/venv/template/Lib/site-packages/urllib3/_request_methods.py +0 -279
- py2docfx/venv/template/Lib/site-packages/urllib3/_version.py +0 -4
- py2docfx/venv/template/Lib/site-packages/urllib3/connection.py +0 -929
- py2docfx/venv/template/Lib/site-packages/urllib3/connectionpool.py +0 -1182
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/emscripten/__init__.py +0 -16
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/emscripten/connection.py +0 -254
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/emscripten/fetch.py +0 -418
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/emscripten/request.py +0 -22
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/emscripten/response.py +0 -285
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/pyopenssl.py +0 -548
- py2docfx/venv/template/Lib/site-packages/urllib3/contrib/socks.py +0 -228
- py2docfx/venv/template/Lib/site-packages/urllib3/exceptions.py +0 -321
- py2docfx/venv/template/Lib/site-packages/urllib3/fields.py +0 -341
- py2docfx/venv/template/Lib/site-packages/urllib3/filepost.py +0 -89
- py2docfx/venv/template/Lib/site-packages/urllib3/http2.py +0 -230
- py2docfx/venv/template/Lib/site-packages/urllib3/poolmanager.py +0 -637
- py2docfx/venv/template/Lib/site-packages/urllib3/response.py +0 -1265
- py2docfx/venv/template/Lib/site-packages/urllib3/util/__init__.py +0 -42
- py2docfx/venv/template/Lib/site-packages/urllib3/util/connection.py +0 -137
- py2docfx/venv/template/Lib/site-packages/urllib3/util/proxy.py +0 -43
- py2docfx/venv/template/Lib/site-packages/urllib3/util/request.py +0 -256
- py2docfx/venv/template/Lib/site-packages/urllib3/util/response.py +0 -101
- py2docfx/venv/template/Lib/site-packages/urllib3/util/retry.py +0 -533
- py2docfx/venv/template/Lib/site-packages/urllib3/util/ssl_.py +0 -509
- py2docfx/venv/template/Lib/site-packages/urllib3/util/ssl_match_hostname.py +0 -159
- py2docfx/venv/template/Lib/site-packages/urllib3/util/ssltransport.py +0 -279
- py2docfx/venv/template/Lib/site-packages/urllib3/util/timeout.py +0 -275
- py2docfx/venv/template/Lib/site-packages/urllib3/util/url.py +0 -471
- py2docfx/venv/template/Lib/site-packages/urllib3/util/util.py +0 -42
- py2docfx/venv/template/Lib/site-packages/urllib3/util/wait.py +0 -124
- py2docfx/venv/template/Lib/site-packages/wheel/__init__.py +0 -3
- py2docfx/venv/template/Lib/site-packages/wheel/__main__.py +0 -23
- py2docfx/venv/template/Lib/site-packages/wheel/_bdist_wheel.py +0 -604
- py2docfx/venv/template/Lib/site-packages/wheel/_setuptools_logging.py +0 -26
- py2docfx/venv/template/Lib/site-packages/wheel/bdist_wheel.py +0 -11
- py2docfx/venv/template/Lib/site-packages/wheel/cli/__init__.py +0 -155
- py2docfx/venv/template/Lib/site-packages/wheel/cli/convert.py +0 -273
- py2docfx/venv/template/Lib/site-packages/wheel/cli/pack.py +0 -85
- py2docfx/venv/template/Lib/site-packages/wheel/cli/tags.py +0 -139
- py2docfx/venv/template/Lib/site-packages/wheel/cli/unpack.py +0 -30
- py2docfx/venv/template/Lib/site-packages/wheel/macosx_libfile.py +0 -482
- py2docfx/venv/template/Lib/site-packages/wheel/metadata.py +0 -183
- py2docfx/venv/template/Lib/site-packages/wheel/util.py +0 -26
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/__init__.py +0 -0
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_elffile.py +0 -108
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_manylinux.py +0 -260
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_musllinux.py +0 -83
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_parser.py +0 -356
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_structures.py +0 -61
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/_tokenizer.py +0 -192
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/markers.py +0 -253
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/requirements.py +0 -90
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/specifiers.py +0 -1011
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/tags.py +0 -571
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/utils.py +0 -172
- py2docfx/venv/template/Lib/site-packages/wheel/vendored/packaging/version.py +0 -561
- py2docfx/venv/template/Lib/site-packages/wheel/wheelfile.py +0 -227
- py2docfx/venv/template/Lib/site-packages/yaml/__init__.py +0 -390
- py2docfx/venv/template/Lib/site-packages/yaml/composer.py +0 -139
- py2docfx/venv/template/Lib/site-packages/yaml/constructor.py +0 -748
- py2docfx/venv/template/Lib/site-packages/yaml/cyaml.py +0 -101
- py2docfx/venv/template/Lib/site-packages/yaml/dumper.py +0 -62
- py2docfx/venv/template/Lib/site-packages/yaml/emitter.py +0 -1137
- py2docfx/venv/template/Lib/site-packages/yaml/error.py +0 -75
- py2docfx/venv/template/Lib/site-packages/yaml/events.py +0 -86
- py2docfx/venv/template/Lib/site-packages/yaml/loader.py +0 -63
- py2docfx/venv/template/Lib/site-packages/yaml/nodes.py +0 -49
- py2docfx/venv/template/Lib/site-packages/yaml/parser.py +0 -589
- py2docfx/venv/template/Lib/site-packages/yaml/reader.py +0 -185
- py2docfx/venv/template/Lib/site-packages/yaml/representer.py +0 -389
- py2docfx/venv/template/Lib/site-packages/yaml/resolver.py +0 -227
- py2docfx/venv/template/Lib/site-packages/yaml/scanner.py +0 -1435
- py2docfx/venv/template/Lib/site-packages/yaml/serializer.py +0 -111
- py2docfx/venv/template/Lib/site-packages/yaml/tokens.py +0 -104
- py2docfx/venv/template/Scripts/rst2html.py +0 -23
- py2docfx/venv/template/Scripts/rst2html4.py +0 -26
- py2docfx/venv/template/Scripts/rst2html5.py +0 -33
- py2docfx/venv/template/Scripts/rst2latex.py +0 -26
- py2docfx/venv/template/Scripts/rst2man.py +0 -27
- py2docfx/venv/template/Scripts/rst2odt.py +0 -28
- py2docfx/venv/template/Scripts/rst2odt_prepstyles.py +0 -65
- py2docfx/venv/template/Scripts/rst2pseudoxml.py +0 -23
- py2docfx/venv/template/Scripts/rst2s5.py +0 -24
- py2docfx/venv/template/Scripts/rst2xetex.py +0 -27
- py2docfx/venv/template/Scripts/rst2xml.py +0 -23
- py2docfx/venv/template/Scripts/rstpep2html.py +0 -25
- py2docfx-0.1.11.dev1830301.dist-info/RECORD +0 -3712
- {py2docfx-0.1.11.dev1830301.dist-info → py2docfx-0.1.11.dev1860114.dist-info}/WHEEL +0 -0
- {py2docfx-0.1.11.dev1830301.dist-info → py2docfx-0.1.11.dev1860114.dist-info}/top_level.txt +0 -0
@@ -1,3880 +0,0 @@
|
|
1
|
-
"""The C language domain."""
|
2
|
-
|
3
|
-
from __future__ import annotations
|
4
|
-
|
5
|
-
import re
|
6
|
-
from typing import Any, Callable, Generator, Iterator, TypeVar, Union, cast
|
7
|
-
|
8
|
-
from docutils import nodes
|
9
|
-
from docutils.nodes import Element, Node, TextElement, system_message
|
10
|
-
from docutils.parsers.rst import directives
|
11
|
-
|
12
|
-
from sphinx import addnodes
|
13
|
-
from sphinx.addnodes import pending_xref
|
14
|
-
from sphinx.application import Sphinx
|
15
|
-
from sphinx.builders import Builder
|
16
|
-
from sphinx.directives import ObjectDescription
|
17
|
-
from sphinx.domains import Domain, ObjType
|
18
|
-
from sphinx.environment import BuildEnvironment
|
19
|
-
from sphinx.locale import _, __
|
20
|
-
from sphinx.roles import SphinxRole, XRefRole
|
21
|
-
from sphinx.transforms import SphinxTransform
|
22
|
-
from sphinx.transforms.post_transforms import ReferencesResolver
|
23
|
-
from sphinx.util import logging
|
24
|
-
from sphinx.util.cfamily import (ASTAttributeList, ASTBaseBase, ASTBaseParenExprList,
|
25
|
-
BaseParser, DefinitionError, NoOldIdError, StringifyTransform,
|
26
|
-
UnsupportedMultiCharacterCharLiteral, anon_identifier_re,
|
27
|
-
binary_literal_re, char_literal_re, float_literal_re,
|
28
|
-
float_literal_suffix_re, hex_literal_re, identifier_re,
|
29
|
-
integer_literal_re, integers_literal_suffix_re,
|
30
|
-
octal_literal_re, verify_description_mode)
|
31
|
-
from sphinx.util.docfields import Field, GroupedField, TypedField
|
32
|
-
from sphinx.util.docutils import SphinxDirective
|
33
|
-
from sphinx.util.nodes import make_refnode
|
34
|
-
from sphinx.util.typing import OptionSpec
|
35
|
-
|
36
|
-
logger = logging.getLogger(__name__)
|
37
|
-
T = TypeVar('T')
|
38
|
-
|
39
|
-
DeclarationType = Union[
|
40
|
-
"ASTStruct", "ASTUnion", "ASTEnum", "ASTEnumerator",
|
41
|
-
"ASTType", "ASTTypeWithInit", "ASTMacro",
|
42
|
-
]
|
43
|
-
|
44
|
-
# https://en.cppreference.com/w/c/keyword
|
45
|
-
_keywords = [
|
46
|
-
'auto', 'break', 'case', 'char', 'const', 'continue', 'default', 'do', 'double',
|
47
|
-
'else', 'enum', 'extern', 'float', 'for', 'goto', 'if', 'inline', 'int', 'long',
|
48
|
-
'register', 'restrict', 'return', 'short', 'signed', 'sizeof', 'static', 'struct',
|
49
|
-
'switch', 'typedef', 'union', 'unsigned', 'void', 'volatile', 'while',
|
50
|
-
'_Alignas', '_Alignof', '_Atomic', '_Bool', '_Complex',
|
51
|
-
'_Decimal32', '_Decimal64', '_Decimal128',
|
52
|
-
'_Generic', '_Imaginary', '_Noreturn', '_Static_assert', '_Thread_local',
|
53
|
-
]
|
54
|
-
# These are only keyword'y when the corresponding headers are included.
|
55
|
-
# They are used as default value for c_extra_keywords.
|
56
|
-
_macroKeywords = [
|
57
|
-
'alignas', 'alignof', 'bool', 'complex', 'imaginary', 'noreturn', 'static_assert',
|
58
|
-
'thread_local',
|
59
|
-
]
|
60
|
-
|
61
|
-
# these are ordered by preceedence
|
62
|
-
_expression_bin_ops = [
|
63
|
-
['||', 'or'],
|
64
|
-
['&&', 'and'],
|
65
|
-
['|', 'bitor'],
|
66
|
-
['^', 'xor'],
|
67
|
-
['&', 'bitand'],
|
68
|
-
['==', '!=', 'not_eq'],
|
69
|
-
['<=', '>=', '<', '>'],
|
70
|
-
['<<', '>>'],
|
71
|
-
['+', '-'],
|
72
|
-
['*', '/', '%'],
|
73
|
-
['.*', '->*']
|
74
|
-
]
|
75
|
-
_expression_unary_ops = ["++", "--", "*", "&", "+", "-", "!", "not", "~", "compl"]
|
76
|
-
_expression_assignment_ops = ["=", "*=", "/=", "%=", "+=", "-=",
|
77
|
-
">>=", "<<=", "&=", "and_eq", "^=", "xor_eq", "|=", "or_eq"]
|
78
|
-
|
79
|
-
_max_id = 1
|
80
|
-
_id_prefix = [None, 'c.', 'Cv2.']
|
81
|
-
# Ids are used in lookup keys which are used across pickled files,
|
82
|
-
# so when _max_id changes, make sure to update the ENV_VERSION.
|
83
|
-
|
84
|
-
_string_re = re.compile(r"[LuU8]?('([^'\\]*(?:\\.[^'\\]*)*)'"
|
85
|
-
r'|"([^"\\]*(?:\\.[^"\\]*)*)")', re.S)
|
86
|
-
|
87
|
-
# bool, complex, and imaginary are macro "keywords", so they are handled seperately
|
88
|
-
_simple_type_specifiers_re = re.compile(r"""
|
89
|
-
\b(
|
90
|
-
void|_Bool
|
91
|
-
|signed|unsigned
|
92
|
-
|short|long
|
93
|
-
|char
|
94
|
-
|int
|
95
|
-
|__uint128|__int128
|
96
|
-
|__int(8|16|32|64|128) # extension
|
97
|
-
|float|double
|
98
|
-
|_Decimal(32|64|128)
|
99
|
-
|_Complex|_Imaginary
|
100
|
-
|__float80|_Float64x|__float128|_Float128|__ibm128 # extension
|
101
|
-
|__fp16 # extension
|
102
|
-
|_Sat|_Fract|fract|_Accum|accum # extension
|
103
|
-
)\b
|
104
|
-
""", re.VERBOSE)
|
105
|
-
|
106
|
-
|
107
|
-
class _DuplicateSymbolError(Exception):
|
108
|
-
def __init__(self, symbol: Symbol, declaration: ASTDeclaration) -> None:
|
109
|
-
assert symbol
|
110
|
-
assert declaration
|
111
|
-
self.symbol = symbol
|
112
|
-
self.declaration = declaration
|
113
|
-
|
114
|
-
def __str__(self) -> str:
|
115
|
-
return "Internal C duplicate symbol error:\n%s" % self.symbol.dump(0)
|
116
|
-
|
117
|
-
|
118
|
-
class ASTBase(ASTBaseBase):
|
119
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
120
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
121
|
-
raise NotImplementedError(repr(self))
|
122
|
-
|
123
|
-
|
124
|
-
# Names
|
125
|
-
################################################################################
|
126
|
-
|
127
|
-
class ASTIdentifier(ASTBaseBase):
|
128
|
-
def __init__(self, identifier: str) -> None:
|
129
|
-
assert identifier is not None
|
130
|
-
assert len(identifier) != 0
|
131
|
-
self.identifier = identifier
|
132
|
-
|
133
|
-
def __eq__(self, other: Any) -> bool:
|
134
|
-
return type(other) is ASTIdentifier and self.identifier == other.identifier
|
135
|
-
|
136
|
-
def is_anon(self) -> bool:
|
137
|
-
return self.identifier[0] == '@'
|
138
|
-
|
139
|
-
# and this is where we finally make a difference between __str__ and the display string
|
140
|
-
|
141
|
-
def __str__(self) -> str:
|
142
|
-
return self.identifier
|
143
|
-
|
144
|
-
def get_display_string(self) -> str:
|
145
|
-
return "[anonymous]" if self.is_anon() else self.identifier
|
146
|
-
|
147
|
-
def describe_signature(self, signode: TextElement, mode: str, env: BuildEnvironment,
|
148
|
-
prefix: str, symbol: Symbol) -> None:
|
149
|
-
# note: slightly different signature of describe_signature due to the prefix
|
150
|
-
verify_description_mode(mode)
|
151
|
-
if self.is_anon():
|
152
|
-
node = addnodes.desc_sig_name(text="[anonymous]")
|
153
|
-
else:
|
154
|
-
node = addnodes.desc_sig_name(self.identifier, self.identifier)
|
155
|
-
if mode == 'markType':
|
156
|
-
targetText = prefix + self.identifier
|
157
|
-
pnode = addnodes.pending_xref('', refdomain='c',
|
158
|
-
reftype='identifier',
|
159
|
-
reftarget=targetText, modname=None,
|
160
|
-
classname=None)
|
161
|
-
pnode['c:parent_key'] = symbol.get_lookup_key()
|
162
|
-
pnode += node
|
163
|
-
signode += pnode
|
164
|
-
elif mode == 'lastIsName':
|
165
|
-
nameNode = addnodes.desc_name()
|
166
|
-
nameNode += node
|
167
|
-
signode += nameNode
|
168
|
-
elif mode == 'noneIsName':
|
169
|
-
signode += node
|
170
|
-
else:
|
171
|
-
raise Exception('Unknown description mode: %s' % mode)
|
172
|
-
|
173
|
-
|
174
|
-
class ASTNestedName(ASTBase):
|
175
|
-
def __init__(self, names: list[ASTIdentifier], rooted: bool) -> None:
|
176
|
-
assert len(names) > 0
|
177
|
-
self.names = names
|
178
|
-
self.rooted = rooted
|
179
|
-
|
180
|
-
@property
|
181
|
-
def name(self) -> ASTNestedName:
|
182
|
-
return self
|
183
|
-
|
184
|
-
def get_id(self, version: int) -> str:
|
185
|
-
return '.'.join(str(n) for n in self.names)
|
186
|
-
|
187
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
188
|
-
res = '.'.join(transform(n) for n in self.names)
|
189
|
-
if self.rooted:
|
190
|
-
return '.' + res
|
191
|
-
else:
|
192
|
-
return res
|
193
|
-
|
194
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
195
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
196
|
-
verify_description_mode(mode)
|
197
|
-
# just print the name part, with template args, not template params
|
198
|
-
if mode == 'noneIsName':
|
199
|
-
if self.rooted:
|
200
|
-
raise AssertionError("Can this happen?") # TODO
|
201
|
-
signode += nodes.Text('.')
|
202
|
-
for i in range(len(self.names)):
|
203
|
-
if i != 0:
|
204
|
-
raise AssertionError("Can this happen?") # TODO
|
205
|
-
signode += nodes.Text('.')
|
206
|
-
n = self.names[i]
|
207
|
-
n.describe_signature(signode, mode, env, '', symbol)
|
208
|
-
elif mode == 'param':
|
209
|
-
assert not self.rooted, str(self)
|
210
|
-
assert len(self.names) == 1
|
211
|
-
self.names[0].describe_signature(signode, 'noneIsName', env, '', symbol)
|
212
|
-
elif mode in ('markType', 'lastIsName', 'markName'):
|
213
|
-
# Each element should be a pending xref targeting the complete
|
214
|
-
# prefix.
|
215
|
-
prefix = ''
|
216
|
-
first = True
|
217
|
-
names = self.names[:-1] if mode == 'lastIsName' else self.names
|
218
|
-
# If lastIsName, then wrap all of the prefix in a desc_addname,
|
219
|
-
# else append directly to signode.
|
220
|
-
# TODO: also for C?
|
221
|
-
# NOTE: Breathe previously relied on the prefix being in the desc_addname node,
|
222
|
-
# so it can remove it in inner declarations.
|
223
|
-
dest = signode
|
224
|
-
if mode == 'lastIsName':
|
225
|
-
dest = addnodes.desc_addname()
|
226
|
-
if self.rooted:
|
227
|
-
prefix += '.'
|
228
|
-
if mode == 'lastIsName' and len(names) == 0:
|
229
|
-
signode += addnodes.desc_sig_punctuation('.', '.')
|
230
|
-
else:
|
231
|
-
dest += addnodes.desc_sig_punctuation('.', '.')
|
232
|
-
for i in range(len(names)):
|
233
|
-
ident = names[i]
|
234
|
-
if not first:
|
235
|
-
dest += addnodes.desc_sig_punctuation('.', '.')
|
236
|
-
prefix += '.'
|
237
|
-
first = False
|
238
|
-
txt_ident = str(ident)
|
239
|
-
if txt_ident != '':
|
240
|
-
ident.describe_signature(dest, 'markType', env, prefix, symbol)
|
241
|
-
prefix += txt_ident
|
242
|
-
if mode == 'lastIsName':
|
243
|
-
if len(self.names) > 1:
|
244
|
-
dest += addnodes.desc_sig_punctuation('.', '.')
|
245
|
-
signode += dest
|
246
|
-
self.names[-1].describe_signature(signode, mode, env, '', symbol)
|
247
|
-
else:
|
248
|
-
raise Exception('Unknown description mode: %s' % mode)
|
249
|
-
|
250
|
-
|
251
|
-
################################################################################
|
252
|
-
# Expressions
|
253
|
-
################################################################################
|
254
|
-
|
255
|
-
class ASTExpression(ASTBase):
|
256
|
-
pass
|
257
|
-
|
258
|
-
|
259
|
-
# Primary expressions
|
260
|
-
################################################################################
|
261
|
-
|
262
|
-
class ASTLiteral(ASTExpression):
|
263
|
-
pass
|
264
|
-
|
265
|
-
|
266
|
-
class ASTBooleanLiteral(ASTLiteral):
|
267
|
-
def __init__(self, value: bool) -> None:
|
268
|
-
self.value = value
|
269
|
-
|
270
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
271
|
-
if self.value:
|
272
|
-
return 'true'
|
273
|
-
else:
|
274
|
-
return 'false'
|
275
|
-
|
276
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
277
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
278
|
-
txt = str(self)
|
279
|
-
signode += addnodes.desc_sig_keyword(txt, txt)
|
280
|
-
|
281
|
-
|
282
|
-
class ASTNumberLiteral(ASTLiteral):
|
283
|
-
def __init__(self, data: str) -> None:
|
284
|
-
self.data = data
|
285
|
-
|
286
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
287
|
-
return self.data
|
288
|
-
|
289
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
290
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
291
|
-
txt = str(self)
|
292
|
-
signode += addnodes.desc_sig_literal_number(txt, txt)
|
293
|
-
|
294
|
-
|
295
|
-
class ASTCharLiteral(ASTLiteral):
|
296
|
-
def __init__(self, prefix: str, data: str) -> None:
|
297
|
-
self.prefix = prefix # may be None when no prefix
|
298
|
-
self.data = data
|
299
|
-
decoded = data.encode().decode('unicode-escape')
|
300
|
-
if len(decoded) == 1:
|
301
|
-
self.value = ord(decoded)
|
302
|
-
else:
|
303
|
-
raise UnsupportedMultiCharacterCharLiteral(decoded)
|
304
|
-
|
305
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
306
|
-
if self.prefix is None:
|
307
|
-
return "'" + self.data + "'"
|
308
|
-
else:
|
309
|
-
return self.prefix + "'" + self.data + "'"
|
310
|
-
|
311
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
312
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
313
|
-
txt = str(self)
|
314
|
-
signode += addnodes.desc_sig_literal_char(txt, txt)
|
315
|
-
|
316
|
-
|
317
|
-
class ASTStringLiteral(ASTLiteral):
|
318
|
-
def __init__(self, data: str) -> None:
|
319
|
-
self.data = data
|
320
|
-
|
321
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
322
|
-
return self.data
|
323
|
-
|
324
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
325
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
326
|
-
txt = str(self)
|
327
|
-
signode += addnodes.desc_sig_literal_string(txt, txt)
|
328
|
-
|
329
|
-
|
330
|
-
class ASTIdExpression(ASTExpression):
|
331
|
-
def __init__(self, name: ASTNestedName):
|
332
|
-
# note: this class is basically to cast a nested name as an expression
|
333
|
-
self.name = name
|
334
|
-
|
335
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
336
|
-
return transform(self.name)
|
337
|
-
|
338
|
-
def get_id(self, version: int) -> str:
|
339
|
-
return self.name.get_id(version)
|
340
|
-
|
341
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
342
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
343
|
-
self.name.describe_signature(signode, mode, env, symbol)
|
344
|
-
|
345
|
-
|
346
|
-
class ASTParenExpr(ASTExpression):
|
347
|
-
def __init__(self, expr):
|
348
|
-
self.expr = expr
|
349
|
-
|
350
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
351
|
-
return '(' + transform(self.expr) + ')'
|
352
|
-
|
353
|
-
def get_id(self, version: int) -> str:
|
354
|
-
return self.expr.get_id(version)
|
355
|
-
|
356
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
357
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
358
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
359
|
-
self.expr.describe_signature(signode, mode, env, symbol)
|
360
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
361
|
-
|
362
|
-
|
363
|
-
# Postfix expressions
|
364
|
-
################################################################################
|
365
|
-
|
366
|
-
class ASTPostfixOp(ASTBase):
|
367
|
-
pass
|
368
|
-
|
369
|
-
|
370
|
-
class ASTPostfixCallExpr(ASTPostfixOp):
|
371
|
-
def __init__(self, lst: ASTParenExprList | ASTBracedInitList) -> None:
|
372
|
-
self.lst = lst
|
373
|
-
|
374
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
375
|
-
return transform(self.lst)
|
376
|
-
|
377
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
378
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
379
|
-
self.lst.describe_signature(signode, mode, env, symbol)
|
380
|
-
|
381
|
-
|
382
|
-
class ASTPostfixArray(ASTPostfixOp):
|
383
|
-
def __init__(self, expr: ASTExpression) -> None:
|
384
|
-
self.expr = expr
|
385
|
-
|
386
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
387
|
-
return '[' + transform(self.expr) + ']'
|
388
|
-
|
389
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
390
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
391
|
-
signode += addnodes.desc_sig_punctuation('[', '[')
|
392
|
-
self.expr.describe_signature(signode, mode, env, symbol)
|
393
|
-
signode += addnodes.desc_sig_punctuation(']', ']')
|
394
|
-
|
395
|
-
|
396
|
-
class ASTPostfixInc(ASTPostfixOp):
|
397
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
398
|
-
return '++'
|
399
|
-
|
400
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
401
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
402
|
-
signode += addnodes.desc_sig_operator('++', '++')
|
403
|
-
|
404
|
-
|
405
|
-
class ASTPostfixDec(ASTPostfixOp):
|
406
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
407
|
-
return '--'
|
408
|
-
|
409
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
410
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
411
|
-
signode += addnodes.desc_sig_operator('--', '--')
|
412
|
-
|
413
|
-
|
414
|
-
class ASTPostfixMemberOfPointer(ASTPostfixOp):
|
415
|
-
def __init__(self, name):
|
416
|
-
self.name = name
|
417
|
-
|
418
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
419
|
-
return '->' + transform(self.name)
|
420
|
-
|
421
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
422
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
423
|
-
signode += addnodes.desc_sig_operator('->', '->')
|
424
|
-
self.name.describe_signature(signode, 'noneIsName', env, symbol)
|
425
|
-
|
426
|
-
|
427
|
-
class ASTPostfixExpr(ASTExpression):
|
428
|
-
def __init__(self, prefix: ASTExpression, postFixes: list[ASTPostfixOp]):
|
429
|
-
self.prefix = prefix
|
430
|
-
self.postFixes = postFixes
|
431
|
-
|
432
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
433
|
-
res = [transform(self.prefix)]
|
434
|
-
for p in self.postFixes:
|
435
|
-
res.append(transform(p))
|
436
|
-
return ''.join(res)
|
437
|
-
|
438
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
439
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
440
|
-
self.prefix.describe_signature(signode, mode, env, symbol)
|
441
|
-
for p in self.postFixes:
|
442
|
-
p.describe_signature(signode, mode, env, symbol)
|
443
|
-
|
444
|
-
|
445
|
-
# Unary expressions
|
446
|
-
################################################################################
|
447
|
-
|
448
|
-
class ASTUnaryOpExpr(ASTExpression):
|
449
|
-
def __init__(self, op: str, expr: ASTExpression):
|
450
|
-
self.op = op
|
451
|
-
self.expr = expr
|
452
|
-
|
453
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
454
|
-
if self.op[0] in 'cn':
|
455
|
-
return self.op + " " + transform(self.expr)
|
456
|
-
else:
|
457
|
-
return self.op + transform(self.expr)
|
458
|
-
|
459
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
460
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
461
|
-
if self.op[0] in 'cn':
|
462
|
-
signode += addnodes.desc_sig_keyword(self.op, self.op)
|
463
|
-
signode += addnodes.desc_sig_space()
|
464
|
-
else:
|
465
|
-
signode += addnodes.desc_sig_operator(self.op, self.op)
|
466
|
-
self.expr.describe_signature(signode, mode, env, symbol)
|
467
|
-
|
468
|
-
|
469
|
-
class ASTSizeofType(ASTExpression):
|
470
|
-
def __init__(self, typ):
|
471
|
-
self.typ = typ
|
472
|
-
|
473
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
474
|
-
return "sizeof(" + transform(self.typ) + ")"
|
475
|
-
|
476
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
477
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
478
|
-
signode += addnodes.desc_sig_keyword('sizeof', 'sizeof')
|
479
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
480
|
-
self.typ.describe_signature(signode, mode, env, symbol)
|
481
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
482
|
-
|
483
|
-
|
484
|
-
class ASTSizeofExpr(ASTExpression):
|
485
|
-
def __init__(self, expr: ASTExpression):
|
486
|
-
self.expr = expr
|
487
|
-
|
488
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
489
|
-
return "sizeof " + transform(self.expr)
|
490
|
-
|
491
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
492
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
493
|
-
signode += addnodes.desc_sig_keyword('sizeof', 'sizeof')
|
494
|
-
signode += addnodes.desc_sig_space()
|
495
|
-
self.expr.describe_signature(signode, mode, env, symbol)
|
496
|
-
|
497
|
-
|
498
|
-
class ASTAlignofExpr(ASTExpression):
|
499
|
-
def __init__(self, typ: ASTType):
|
500
|
-
self.typ = typ
|
501
|
-
|
502
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
503
|
-
return "alignof(" + transform(self.typ) + ")"
|
504
|
-
|
505
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
506
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
507
|
-
signode += addnodes.desc_sig_keyword('alignof', 'alignof')
|
508
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
509
|
-
self.typ.describe_signature(signode, mode, env, symbol)
|
510
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
511
|
-
|
512
|
-
|
513
|
-
# Other expressions
|
514
|
-
################################################################################
|
515
|
-
|
516
|
-
class ASTCastExpr(ASTExpression):
|
517
|
-
def __init__(self, typ: ASTType, expr: ASTExpression):
|
518
|
-
self.typ = typ
|
519
|
-
self.expr = expr
|
520
|
-
|
521
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
522
|
-
res = ['(']
|
523
|
-
res.append(transform(self.typ))
|
524
|
-
res.append(')')
|
525
|
-
res.append(transform(self.expr))
|
526
|
-
return ''.join(res)
|
527
|
-
|
528
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
529
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
530
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
531
|
-
self.typ.describe_signature(signode, mode, env, symbol)
|
532
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
533
|
-
self.expr.describe_signature(signode, mode, env, symbol)
|
534
|
-
|
535
|
-
|
536
|
-
class ASTBinOpExpr(ASTBase):
|
537
|
-
def __init__(self, exprs: list[ASTExpression], ops: list[str]):
|
538
|
-
assert len(exprs) > 0
|
539
|
-
assert len(exprs) == len(ops) + 1
|
540
|
-
self.exprs = exprs
|
541
|
-
self.ops = ops
|
542
|
-
|
543
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
544
|
-
res = []
|
545
|
-
res.append(transform(self.exprs[0]))
|
546
|
-
for i in range(1, len(self.exprs)):
|
547
|
-
res.append(' ')
|
548
|
-
res.append(self.ops[i - 1])
|
549
|
-
res.append(' ')
|
550
|
-
res.append(transform(self.exprs[i]))
|
551
|
-
return ''.join(res)
|
552
|
-
|
553
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
554
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
555
|
-
self.exprs[0].describe_signature(signode, mode, env, symbol)
|
556
|
-
for i in range(1, len(self.exprs)):
|
557
|
-
signode += addnodes.desc_sig_space()
|
558
|
-
op = self.ops[i - 1]
|
559
|
-
if ord(op[0]) >= ord('a') and ord(op[0]) <= ord('z'):
|
560
|
-
signode += addnodes.desc_sig_keyword(op, op)
|
561
|
-
else:
|
562
|
-
signode += addnodes.desc_sig_operator(op, op)
|
563
|
-
signode += addnodes.desc_sig_space()
|
564
|
-
self.exprs[i].describe_signature(signode, mode, env, symbol)
|
565
|
-
|
566
|
-
|
567
|
-
class ASTAssignmentExpr(ASTExpression):
|
568
|
-
def __init__(self, exprs: list[ASTExpression], ops: list[str]):
|
569
|
-
assert len(exprs) > 0
|
570
|
-
assert len(exprs) == len(ops) + 1
|
571
|
-
self.exprs = exprs
|
572
|
-
self.ops = ops
|
573
|
-
|
574
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
575
|
-
res = []
|
576
|
-
res.append(transform(self.exprs[0]))
|
577
|
-
for i in range(1, len(self.exprs)):
|
578
|
-
res.append(' ')
|
579
|
-
res.append(self.ops[i - 1])
|
580
|
-
res.append(' ')
|
581
|
-
res.append(transform(self.exprs[i]))
|
582
|
-
return ''.join(res)
|
583
|
-
|
584
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
585
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
586
|
-
self.exprs[0].describe_signature(signode, mode, env, symbol)
|
587
|
-
for i in range(1, len(self.exprs)):
|
588
|
-
signode += addnodes.desc_sig_space()
|
589
|
-
op = self.ops[i - 1]
|
590
|
-
if ord(op[0]) >= ord('a') and ord(op[0]) <= ord('z'):
|
591
|
-
signode += addnodes.desc_sig_keyword(op, op)
|
592
|
-
else:
|
593
|
-
signode += addnodes.desc_sig_operator(op, op)
|
594
|
-
signode += addnodes.desc_sig_space()
|
595
|
-
self.exprs[i].describe_signature(signode, mode, env, symbol)
|
596
|
-
|
597
|
-
|
598
|
-
class ASTFallbackExpr(ASTExpression):
|
599
|
-
def __init__(self, expr: str):
|
600
|
-
self.expr = expr
|
601
|
-
|
602
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
603
|
-
return self.expr
|
604
|
-
|
605
|
-
def get_id(self, version: int) -> str:
|
606
|
-
return str(self.expr)
|
607
|
-
|
608
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
609
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
610
|
-
signode += nodes.literal(self.expr, self.expr)
|
611
|
-
|
612
|
-
|
613
|
-
################################################################################
|
614
|
-
# Types
|
615
|
-
################################################################################
|
616
|
-
|
617
|
-
class ASTTrailingTypeSpec(ASTBase):
|
618
|
-
pass
|
619
|
-
|
620
|
-
|
621
|
-
class ASTTrailingTypeSpecFundamental(ASTTrailingTypeSpec):
|
622
|
-
def __init__(self, names: list[str]) -> None:
|
623
|
-
assert len(names) != 0
|
624
|
-
self.names = names
|
625
|
-
|
626
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
627
|
-
return ' '.join(self.names)
|
628
|
-
|
629
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
630
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
631
|
-
first = True
|
632
|
-
for n in self.names:
|
633
|
-
if not first:
|
634
|
-
signode += addnodes.desc_sig_space()
|
635
|
-
else:
|
636
|
-
first = False
|
637
|
-
signode += addnodes.desc_sig_keyword_type(n, n)
|
638
|
-
|
639
|
-
|
640
|
-
class ASTTrailingTypeSpecName(ASTTrailingTypeSpec):
|
641
|
-
def __init__(self, prefix: str, nestedName: ASTNestedName) -> None:
|
642
|
-
self.prefix = prefix
|
643
|
-
self.nestedName = nestedName
|
644
|
-
|
645
|
-
@property
|
646
|
-
def name(self) -> ASTNestedName:
|
647
|
-
return self.nestedName
|
648
|
-
|
649
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
650
|
-
res = []
|
651
|
-
if self.prefix:
|
652
|
-
res.append(self.prefix)
|
653
|
-
res.append(' ')
|
654
|
-
res.append(transform(self.nestedName))
|
655
|
-
return ''.join(res)
|
656
|
-
|
657
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
658
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
659
|
-
if self.prefix:
|
660
|
-
signode += addnodes.desc_sig_keyword(self.prefix, self.prefix)
|
661
|
-
signode += addnodes.desc_sig_space()
|
662
|
-
self.nestedName.describe_signature(signode, mode, env, symbol=symbol)
|
663
|
-
|
664
|
-
|
665
|
-
class ASTFunctionParameter(ASTBase):
|
666
|
-
def __init__(self, arg: ASTTypeWithInit | None, ellipsis: bool = False) -> None:
|
667
|
-
self.arg = arg
|
668
|
-
self.ellipsis = ellipsis
|
669
|
-
|
670
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
671
|
-
# the anchor will be our parent
|
672
|
-
return symbol.parent.declaration.get_id(version, prefixed=False)
|
673
|
-
|
674
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
675
|
-
if self.ellipsis:
|
676
|
-
return '...'
|
677
|
-
else:
|
678
|
-
return transform(self.arg)
|
679
|
-
|
680
|
-
def describe_signature(self, signode: Any, mode: str,
|
681
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
682
|
-
verify_description_mode(mode)
|
683
|
-
if self.ellipsis:
|
684
|
-
signode += addnodes.desc_sig_punctuation('...', '...')
|
685
|
-
else:
|
686
|
-
self.arg.describe_signature(signode, mode, env, symbol=symbol)
|
687
|
-
|
688
|
-
|
689
|
-
class ASTParameters(ASTBase):
|
690
|
-
def __init__(self, args: list[ASTFunctionParameter], attrs: ASTAttributeList) -> None:
|
691
|
-
self.args = args
|
692
|
-
self.attrs = attrs
|
693
|
-
|
694
|
-
@property
|
695
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
696
|
-
return self.args
|
697
|
-
|
698
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
699
|
-
res = []
|
700
|
-
res.append('(')
|
701
|
-
first = True
|
702
|
-
for a in self.args:
|
703
|
-
if not first:
|
704
|
-
res.append(', ')
|
705
|
-
first = False
|
706
|
-
res.append(str(a))
|
707
|
-
res.append(')')
|
708
|
-
if len(self.attrs) != 0:
|
709
|
-
res.append(' ')
|
710
|
-
res.append(transform(self.attrs))
|
711
|
-
return ''.join(res)
|
712
|
-
|
713
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
714
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
715
|
-
verify_description_mode(mode)
|
716
|
-
# only use the desc_parameterlist for the outer list, not for inner lists
|
717
|
-
if mode == 'lastIsName':
|
718
|
-
paramlist = addnodes.desc_parameterlist()
|
719
|
-
for arg in self.args:
|
720
|
-
param = addnodes.desc_parameter('', '', noemph=True)
|
721
|
-
arg.describe_signature(param, 'param', env, symbol=symbol)
|
722
|
-
paramlist += param
|
723
|
-
signode += paramlist
|
724
|
-
else:
|
725
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
726
|
-
first = True
|
727
|
-
for arg in self.args:
|
728
|
-
if not first:
|
729
|
-
signode += addnodes.desc_sig_punctuation(',', ',')
|
730
|
-
signode += addnodes.desc_sig_space()
|
731
|
-
first = False
|
732
|
-
arg.describe_signature(signode, 'markType', env, symbol=symbol)
|
733
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
734
|
-
|
735
|
-
if len(self.attrs) != 0:
|
736
|
-
signode += addnodes.desc_sig_space()
|
737
|
-
self.attrs.describe_signature(signode)
|
738
|
-
|
739
|
-
|
740
|
-
class ASTDeclSpecsSimple(ASTBaseBase):
|
741
|
-
def __init__(self, storage: str, threadLocal: str, inline: bool,
|
742
|
-
restrict: bool, volatile: bool, const: bool, attrs: ASTAttributeList) -> None:
|
743
|
-
self.storage = storage
|
744
|
-
self.threadLocal = threadLocal
|
745
|
-
self.inline = inline
|
746
|
-
self.restrict = restrict
|
747
|
-
self.volatile = volatile
|
748
|
-
self.const = const
|
749
|
-
self.attrs = attrs
|
750
|
-
|
751
|
-
def mergeWith(self, other: ASTDeclSpecsSimple) -> ASTDeclSpecsSimple:
|
752
|
-
if not other:
|
753
|
-
return self
|
754
|
-
return ASTDeclSpecsSimple(self.storage or other.storage,
|
755
|
-
self.threadLocal or other.threadLocal,
|
756
|
-
self.inline or other.inline,
|
757
|
-
self.volatile or other.volatile,
|
758
|
-
self.const or other.const,
|
759
|
-
self.restrict or other.restrict,
|
760
|
-
self.attrs + other.attrs)
|
761
|
-
|
762
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
763
|
-
res: list[str] = []
|
764
|
-
if len(self.attrs) != 0:
|
765
|
-
res.append(transform(self.attrs))
|
766
|
-
if self.storage:
|
767
|
-
res.append(self.storage)
|
768
|
-
if self.threadLocal:
|
769
|
-
res.append(self.threadLocal)
|
770
|
-
if self.inline:
|
771
|
-
res.append('inline')
|
772
|
-
if self.restrict:
|
773
|
-
res.append('restrict')
|
774
|
-
if self.volatile:
|
775
|
-
res.append('volatile')
|
776
|
-
if self.const:
|
777
|
-
res.append('const')
|
778
|
-
return ' '.join(res)
|
779
|
-
|
780
|
-
def describe_signature(self, modifiers: list[Node]) -> None:
|
781
|
-
def _add(modifiers: list[Node], text: str) -> None:
|
782
|
-
if len(modifiers) != 0:
|
783
|
-
modifiers.append(addnodes.desc_sig_space())
|
784
|
-
modifiers.append(addnodes.desc_sig_keyword(text, text))
|
785
|
-
|
786
|
-
if len(modifiers) != 0 and len(self.attrs) != 0:
|
787
|
-
modifiers.append(addnodes.desc_sig_space())
|
788
|
-
tempNode = nodes.TextElement()
|
789
|
-
self.attrs.describe_signature(tempNode)
|
790
|
-
modifiers.extend(tempNode.children)
|
791
|
-
if self.storage:
|
792
|
-
_add(modifiers, self.storage)
|
793
|
-
if self.threadLocal:
|
794
|
-
_add(modifiers, self.threadLocal)
|
795
|
-
if self.inline:
|
796
|
-
_add(modifiers, 'inline')
|
797
|
-
if self.restrict:
|
798
|
-
_add(modifiers, 'restrict')
|
799
|
-
if self.volatile:
|
800
|
-
_add(modifiers, 'volatile')
|
801
|
-
if self.const:
|
802
|
-
_add(modifiers, 'const')
|
803
|
-
|
804
|
-
|
805
|
-
class ASTDeclSpecs(ASTBase):
|
806
|
-
def __init__(self, outer: str,
|
807
|
-
leftSpecs: ASTDeclSpecsSimple,
|
808
|
-
rightSpecs: ASTDeclSpecsSimple,
|
809
|
-
trailing: ASTTrailingTypeSpec) -> None:
|
810
|
-
# leftSpecs and rightSpecs are used for output
|
811
|
-
# allSpecs are used for id generation TODO: remove?
|
812
|
-
self.outer = outer
|
813
|
-
self.leftSpecs = leftSpecs
|
814
|
-
self.rightSpecs = rightSpecs
|
815
|
-
self.allSpecs = self.leftSpecs.mergeWith(self.rightSpecs)
|
816
|
-
self.trailingTypeSpec = trailing
|
817
|
-
|
818
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
819
|
-
res: list[str] = []
|
820
|
-
l = transform(self.leftSpecs)
|
821
|
-
if len(l) > 0:
|
822
|
-
res.append(l)
|
823
|
-
if self.trailingTypeSpec:
|
824
|
-
if len(res) > 0:
|
825
|
-
res.append(" ")
|
826
|
-
res.append(transform(self.trailingTypeSpec))
|
827
|
-
r = str(self.rightSpecs)
|
828
|
-
if len(r) > 0:
|
829
|
-
if len(res) > 0:
|
830
|
-
res.append(" ")
|
831
|
-
res.append(r)
|
832
|
-
return "".join(res)
|
833
|
-
|
834
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
835
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
836
|
-
verify_description_mode(mode)
|
837
|
-
modifiers: list[Node] = []
|
838
|
-
|
839
|
-
self.leftSpecs.describe_signature(modifiers)
|
840
|
-
|
841
|
-
for m in modifiers:
|
842
|
-
signode += m
|
843
|
-
if self.trailingTypeSpec:
|
844
|
-
if len(modifiers) > 0:
|
845
|
-
signode += addnodes.desc_sig_space()
|
846
|
-
self.trailingTypeSpec.describe_signature(signode, mode, env,
|
847
|
-
symbol=symbol)
|
848
|
-
modifiers = []
|
849
|
-
self.rightSpecs.describe_signature(modifiers)
|
850
|
-
if len(modifiers) > 0:
|
851
|
-
signode += addnodes.desc_sig_space()
|
852
|
-
for m in modifiers:
|
853
|
-
signode += m
|
854
|
-
|
855
|
-
|
856
|
-
# Declarator
|
857
|
-
################################################################################
|
858
|
-
|
859
|
-
class ASTArray(ASTBase):
|
860
|
-
def __init__(self, static: bool, const: bool, volatile: bool, restrict: bool,
|
861
|
-
vla: bool, size: ASTExpression):
|
862
|
-
self.static = static
|
863
|
-
self.const = const
|
864
|
-
self.volatile = volatile
|
865
|
-
self.restrict = restrict
|
866
|
-
self.vla = vla
|
867
|
-
self.size = size
|
868
|
-
if vla:
|
869
|
-
assert size is None
|
870
|
-
if size is not None:
|
871
|
-
assert not vla
|
872
|
-
|
873
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
874
|
-
el = []
|
875
|
-
if self.static:
|
876
|
-
el.append('static')
|
877
|
-
if self.restrict:
|
878
|
-
el.append('restrict')
|
879
|
-
if self.volatile:
|
880
|
-
el.append('volatile')
|
881
|
-
if self.const:
|
882
|
-
el.append('const')
|
883
|
-
if self.vla:
|
884
|
-
return '[' + ' '.join(el) + '*]'
|
885
|
-
elif self.size:
|
886
|
-
el.append(transform(self.size))
|
887
|
-
return '[' + ' '.join(el) + ']'
|
888
|
-
|
889
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
890
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
891
|
-
verify_description_mode(mode)
|
892
|
-
signode += addnodes.desc_sig_punctuation('[', '[')
|
893
|
-
addSpace = False
|
894
|
-
|
895
|
-
def _add(signode: TextElement, text: str) -> bool:
|
896
|
-
if addSpace:
|
897
|
-
signode += addnodes.desc_sig_space()
|
898
|
-
signode += addnodes.desc_sig_keyword(text, text)
|
899
|
-
return True
|
900
|
-
|
901
|
-
if self.static:
|
902
|
-
addSpace = _add(signode, 'static')
|
903
|
-
if self.restrict:
|
904
|
-
addSpace = _add(signode, 'restrict')
|
905
|
-
if self.volatile:
|
906
|
-
addSpace = _add(signode, 'volatile')
|
907
|
-
if self.const:
|
908
|
-
addSpace = _add(signode, 'const')
|
909
|
-
if self.vla:
|
910
|
-
signode += addnodes.desc_sig_punctuation('*', '*')
|
911
|
-
elif self.size:
|
912
|
-
if addSpace:
|
913
|
-
signode += addnodes.desc_sig_space()
|
914
|
-
self.size.describe_signature(signode, 'markType', env, symbol)
|
915
|
-
signode += addnodes.desc_sig_punctuation(']', ']')
|
916
|
-
|
917
|
-
|
918
|
-
class ASTDeclarator(ASTBase):
|
919
|
-
@property
|
920
|
-
def name(self) -> ASTNestedName:
|
921
|
-
raise NotImplementedError(repr(self))
|
922
|
-
|
923
|
-
@property
|
924
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
925
|
-
raise NotImplementedError(repr(self))
|
926
|
-
|
927
|
-
def require_space_after_declSpecs(self) -> bool:
|
928
|
-
raise NotImplementedError(repr(self))
|
929
|
-
|
930
|
-
|
931
|
-
class ASTDeclaratorNameParam(ASTDeclarator):
|
932
|
-
def __init__(self, declId: ASTNestedName,
|
933
|
-
arrayOps: list[ASTArray], param: ASTParameters) -> None:
|
934
|
-
self.declId = declId
|
935
|
-
self.arrayOps = arrayOps
|
936
|
-
self.param = param
|
937
|
-
|
938
|
-
@property
|
939
|
-
def name(self) -> ASTNestedName:
|
940
|
-
return self.declId
|
941
|
-
|
942
|
-
@property
|
943
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
944
|
-
return self.param.function_params
|
945
|
-
|
946
|
-
# ------------------------------------------------------------------------
|
947
|
-
|
948
|
-
def require_space_after_declSpecs(self) -> bool:
|
949
|
-
return self.declId is not None
|
950
|
-
|
951
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
952
|
-
res = []
|
953
|
-
if self.declId:
|
954
|
-
res.append(transform(self.declId))
|
955
|
-
for op in self.arrayOps:
|
956
|
-
res.append(transform(op))
|
957
|
-
if self.param:
|
958
|
-
res.append(transform(self.param))
|
959
|
-
return ''.join(res)
|
960
|
-
|
961
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
962
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
963
|
-
verify_description_mode(mode)
|
964
|
-
if self.declId:
|
965
|
-
self.declId.describe_signature(signode, mode, env, symbol)
|
966
|
-
for op in self.arrayOps:
|
967
|
-
op.describe_signature(signode, mode, env, symbol)
|
968
|
-
if self.param:
|
969
|
-
self.param.describe_signature(signode, mode, env, symbol)
|
970
|
-
|
971
|
-
|
972
|
-
class ASTDeclaratorNameBitField(ASTDeclarator):
|
973
|
-
def __init__(self, declId: ASTNestedName, size: ASTExpression):
|
974
|
-
self.declId = declId
|
975
|
-
self.size = size
|
976
|
-
|
977
|
-
@property
|
978
|
-
def name(self) -> ASTNestedName:
|
979
|
-
return self.declId
|
980
|
-
|
981
|
-
# ------------------------------------------------------------------------
|
982
|
-
|
983
|
-
def require_space_after_declSpecs(self) -> bool:
|
984
|
-
return self.declId is not None
|
985
|
-
|
986
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
987
|
-
res = []
|
988
|
-
if self.declId:
|
989
|
-
res.append(transform(self.declId))
|
990
|
-
res.append(" : ")
|
991
|
-
res.append(transform(self.size))
|
992
|
-
return ''.join(res)
|
993
|
-
|
994
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
995
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
996
|
-
verify_description_mode(mode)
|
997
|
-
if self.declId:
|
998
|
-
self.declId.describe_signature(signode, mode, env, symbol)
|
999
|
-
signode += addnodes.desc_sig_space()
|
1000
|
-
signode += addnodes.desc_sig_punctuation(':', ':')
|
1001
|
-
signode += addnodes.desc_sig_space()
|
1002
|
-
self.size.describe_signature(signode, mode, env, symbol)
|
1003
|
-
|
1004
|
-
|
1005
|
-
class ASTDeclaratorPtr(ASTDeclarator):
|
1006
|
-
def __init__(self, next: ASTDeclarator, restrict: bool, volatile: bool, const: bool,
|
1007
|
-
attrs: ASTAttributeList) -> None:
|
1008
|
-
assert next
|
1009
|
-
self.next = next
|
1010
|
-
self.restrict = restrict
|
1011
|
-
self.volatile = volatile
|
1012
|
-
self.const = const
|
1013
|
-
self.attrs = attrs
|
1014
|
-
|
1015
|
-
@property
|
1016
|
-
def name(self) -> ASTNestedName:
|
1017
|
-
return self.next.name
|
1018
|
-
|
1019
|
-
@property
|
1020
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
1021
|
-
return self.next.function_params
|
1022
|
-
|
1023
|
-
def require_space_after_declSpecs(self) -> bool:
|
1024
|
-
return self.const or self.volatile or self.restrict or \
|
1025
|
-
len(self.attrs) > 0 or \
|
1026
|
-
self.next.require_space_after_declSpecs()
|
1027
|
-
|
1028
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1029
|
-
res = ['*']
|
1030
|
-
res.append(transform(self.attrs))
|
1031
|
-
if len(self.attrs) != 0 and (self.restrict or self.volatile or self.const):
|
1032
|
-
res.append(' ')
|
1033
|
-
if self.restrict:
|
1034
|
-
res.append('restrict')
|
1035
|
-
if self.volatile:
|
1036
|
-
if self.restrict:
|
1037
|
-
res.append(' ')
|
1038
|
-
res.append('volatile')
|
1039
|
-
if self.const:
|
1040
|
-
if self.restrict or self.volatile:
|
1041
|
-
res.append(' ')
|
1042
|
-
res.append('const')
|
1043
|
-
if self.const or self.volatile or self.restrict or len(self.attrs) > 0:
|
1044
|
-
if self.next.require_space_after_declSpecs():
|
1045
|
-
res.append(' ')
|
1046
|
-
res.append(transform(self.next))
|
1047
|
-
return ''.join(res)
|
1048
|
-
|
1049
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1050
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1051
|
-
verify_description_mode(mode)
|
1052
|
-
signode += addnodes.desc_sig_punctuation('*', '*')
|
1053
|
-
self.attrs.describe_signature(signode)
|
1054
|
-
if len(self.attrs) != 0 and (self.restrict or self.volatile or self.const):
|
1055
|
-
signode += addnodes.desc_sig_space()
|
1056
|
-
|
1057
|
-
def _add_anno(signode: TextElement, text: str) -> None:
|
1058
|
-
signode += addnodes.desc_sig_keyword(text, text)
|
1059
|
-
|
1060
|
-
if self.restrict:
|
1061
|
-
_add_anno(signode, 'restrict')
|
1062
|
-
if self.volatile:
|
1063
|
-
if self.restrict:
|
1064
|
-
signode += addnodes.desc_sig_space()
|
1065
|
-
_add_anno(signode, 'volatile')
|
1066
|
-
if self.const:
|
1067
|
-
if self.restrict or self.volatile:
|
1068
|
-
signode += addnodes.desc_sig_space()
|
1069
|
-
_add_anno(signode, 'const')
|
1070
|
-
if self.const or self.volatile or self.restrict or len(self.attrs) > 0:
|
1071
|
-
if self.next.require_space_after_declSpecs():
|
1072
|
-
signode += addnodes.desc_sig_space()
|
1073
|
-
self.next.describe_signature(signode, mode, env, symbol)
|
1074
|
-
|
1075
|
-
|
1076
|
-
class ASTDeclaratorParen(ASTDeclarator):
|
1077
|
-
def __init__(self, inner: ASTDeclarator, next: ASTDeclarator) -> None:
|
1078
|
-
assert inner
|
1079
|
-
assert next
|
1080
|
-
self.inner = inner
|
1081
|
-
self.next = next
|
1082
|
-
# TODO: we assume the name and params are in inner
|
1083
|
-
|
1084
|
-
@property
|
1085
|
-
def name(self) -> ASTNestedName:
|
1086
|
-
return self.inner.name
|
1087
|
-
|
1088
|
-
@property
|
1089
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
1090
|
-
return self.inner.function_params
|
1091
|
-
|
1092
|
-
def require_space_after_declSpecs(self) -> bool:
|
1093
|
-
return True
|
1094
|
-
|
1095
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1096
|
-
res = ['(']
|
1097
|
-
res.append(transform(self.inner))
|
1098
|
-
res.append(')')
|
1099
|
-
res.append(transform(self.next))
|
1100
|
-
return ''.join(res)
|
1101
|
-
|
1102
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1103
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1104
|
-
verify_description_mode(mode)
|
1105
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
1106
|
-
self.inner.describe_signature(signode, mode, env, symbol)
|
1107
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
1108
|
-
self.next.describe_signature(signode, "noneIsName", env, symbol)
|
1109
|
-
|
1110
|
-
|
1111
|
-
# Initializer
|
1112
|
-
################################################################################
|
1113
|
-
|
1114
|
-
class ASTParenExprList(ASTBaseParenExprList):
|
1115
|
-
def __init__(self, exprs: list[ASTExpression]) -> None:
|
1116
|
-
self.exprs = exprs
|
1117
|
-
|
1118
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1119
|
-
exprs = [transform(e) for e in self.exprs]
|
1120
|
-
return '(%s)' % ', '.join(exprs)
|
1121
|
-
|
1122
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1123
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1124
|
-
verify_description_mode(mode)
|
1125
|
-
signode += addnodes.desc_sig_punctuation('(', '(')
|
1126
|
-
first = True
|
1127
|
-
for e in self.exprs:
|
1128
|
-
if not first:
|
1129
|
-
signode += addnodes.desc_sig_punctuation(',', ',')
|
1130
|
-
signode += addnodes.desc_sig_space()
|
1131
|
-
else:
|
1132
|
-
first = False
|
1133
|
-
e.describe_signature(signode, mode, env, symbol)
|
1134
|
-
signode += addnodes.desc_sig_punctuation(')', ')')
|
1135
|
-
|
1136
|
-
|
1137
|
-
class ASTBracedInitList(ASTBase):
|
1138
|
-
def __init__(self, exprs: list[ASTExpression], trailingComma: bool) -> None:
|
1139
|
-
self.exprs = exprs
|
1140
|
-
self.trailingComma = trailingComma
|
1141
|
-
|
1142
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1143
|
-
exprs = ', '.join(transform(e) for e in self.exprs)
|
1144
|
-
trailingComma = ',' if self.trailingComma else ''
|
1145
|
-
return f'{{{exprs}{trailingComma}}}'
|
1146
|
-
|
1147
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1148
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1149
|
-
verify_description_mode(mode)
|
1150
|
-
signode += addnodes.desc_sig_punctuation('{', '{')
|
1151
|
-
first = True
|
1152
|
-
for e in self.exprs:
|
1153
|
-
if not first:
|
1154
|
-
signode += addnodes.desc_sig_punctuation(',', ',')
|
1155
|
-
signode += addnodes.desc_sig_space()
|
1156
|
-
else:
|
1157
|
-
first = False
|
1158
|
-
e.describe_signature(signode, mode, env, symbol)
|
1159
|
-
if self.trailingComma:
|
1160
|
-
signode += addnodes.desc_sig_punctuation(',', ',')
|
1161
|
-
signode += addnodes.desc_sig_punctuation('}', '}')
|
1162
|
-
|
1163
|
-
|
1164
|
-
class ASTInitializer(ASTBase):
|
1165
|
-
def __init__(self, value: ASTBracedInitList | ASTExpression,
|
1166
|
-
hasAssign: bool = True) -> None:
|
1167
|
-
self.value = value
|
1168
|
-
self.hasAssign = hasAssign
|
1169
|
-
|
1170
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1171
|
-
val = transform(self.value)
|
1172
|
-
if self.hasAssign:
|
1173
|
-
return ' = ' + val
|
1174
|
-
else:
|
1175
|
-
return val
|
1176
|
-
|
1177
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1178
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1179
|
-
verify_description_mode(mode)
|
1180
|
-
if self.hasAssign:
|
1181
|
-
signode += addnodes.desc_sig_space()
|
1182
|
-
signode += addnodes.desc_sig_punctuation('=', '=')
|
1183
|
-
signode += addnodes.desc_sig_space()
|
1184
|
-
self.value.describe_signature(signode, 'markType', env, symbol)
|
1185
|
-
|
1186
|
-
|
1187
|
-
class ASTType(ASTBase):
|
1188
|
-
def __init__(self, declSpecs: ASTDeclSpecs, decl: ASTDeclarator) -> None:
|
1189
|
-
assert declSpecs
|
1190
|
-
assert decl
|
1191
|
-
self.declSpecs = declSpecs
|
1192
|
-
self.decl = decl
|
1193
|
-
|
1194
|
-
@property
|
1195
|
-
def name(self) -> ASTNestedName:
|
1196
|
-
return self.decl.name
|
1197
|
-
|
1198
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1199
|
-
return symbol.get_full_nested_name().get_id(version)
|
1200
|
-
|
1201
|
-
@property
|
1202
|
-
def function_params(self) -> list[ASTFunctionParameter]:
|
1203
|
-
return self.decl.function_params
|
1204
|
-
|
1205
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1206
|
-
res = []
|
1207
|
-
declSpecs = transform(self.declSpecs)
|
1208
|
-
res.append(declSpecs)
|
1209
|
-
if self.decl.require_space_after_declSpecs() and len(declSpecs) > 0:
|
1210
|
-
res.append(' ')
|
1211
|
-
res.append(transform(self.decl))
|
1212
|
-
return ''.join(res)
|
1213
|
-
|
1214
|
-
def get_type_declaration_prefix(self) -> str:
|
1215
|
-
if self.declSpecs.trailingTypeSpec:
|
1216
|
-
return 'typedef'
|
1217
|
-
else:
|
1218
|
-
return 'type'
|
1219
|
-
|
1220
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1221
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1222
|
-
verify_description_mode(mode)
|
1223
|
-
self.declSpecs.describe_signature(signode, 'markType', env, symbol)
|
1224
|
-
if (self.decl.require_space_after_declSpecs() and
|
1225
|
-
len(str(self.declSpecs)) > 0):
|
1226
|
-
signode += addnodes.desc_sig_space()
|
1227
|
-
# for parameters that don't really declare new names we get 'markType',
|
1228
|
-
# this should not be propagated, but be 'noneIsName'.
|
1229
|
-
if mode == 'markType':
|
1230
|
-
mode = 'noneIsName'
|
1231
|
-
self.decl.describe_signature(signode, mode, env, symbol)
|
1232
|
-
|
1233
|
-
|
1234
|
-
class ASTTypeWithInit(ASTBase):
|
1235
|
-
def __init__(self, type: ASTType, init: ASTInitializer) -> None:
|
1236
|
-
self.type = type
|
1237
|
-
self.init = init
|
1238
|
-
|
1239
|
-
@property
|
1240
|
-
def name(self) -> ASTNestedName:
|
1241
|
-
return self.type.name
|
1242
|
-
|
1243
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1244
|
-
return self.type.get_id(version, objectType, symbol)
|
1245
|
-
|
1246
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1247
|
-
res = []
|
1248
|
-
res.append(transform(self.type))
|
1249
|
-
if self.init:
|
1250
|
-
res.append(transform(self.init))
|
1251
|
-
return ''.join(res)
|
1252
|
-
|
1253
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1254
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1255
|
-
verify_description_mode(mode)
|
1256
|
-
self.type.describe_signature(signode, mode, env, symbol)
|
1257
|
-
if self.init:
|
1258
|
-
self.init.describe_signature(signode, mode, env, symbol)
|
1259
|
-
|
1260
|
-
|
1261
|
-
class ASTMacroParameter(ASTBase):
|
1262
|
-
def __init__(self, arg: ASTNestedName | None, ellipsis: bool = False,
|
1263
|
-
variadic: bool = False) -> None:
|
1264
|
-
self.arg = arg
|
1265
|
-
self.ellipsis = ellipsis
|
1266
|
-
self.variadic = variadic
|
1267
|
-
|
1268
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1269
|
-
if self.ellipsis:
|
1270
|
-
return '...'
|
1271
|
-
elif self.variadic:
|
1272
|
-
return transform(self.arg) + '...'
|
1273
|
-
else:
|
1274
|
-
return transform(self.arg)
|
1275
|
-
|
1276
|
-
def describe_signature(self, signode: Any, mode: str,
|
1277
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1278
|
-
verify_description_mode(mode)
|
1279
|
-
if self.ellipsis:
|
1280
|
-
signode += addnodes.desc_sig_punctuation('...', '...')
|
1281
|
-
elif self.variadic:
|
1282
|
-
name = str(self)
|
1283
|
-
signode += addnodes.desc_sig_name(name, name)
|
1284
|
-
else:
|
1285
|
-
self.arg.describe_signature(signode, mode, env, symbol=symbol)
|
1286
|
-
|
1287
|
-
|
1288
|
-
class ASTMacro(ASTBase):
|
1289
|
-
def __init__(self, ident: ASTNestedName, args: list[ASTMacroParameter] | None) -> None:
|
1290
|
-
self.ident = ident
|
1291
|
-
self.args = args
|
1292
|
-
|
1293
|
-
@property
|
1294
|
-
def name(self) -> ASTNestedName:
|
1295
|
-
return self.ident
|
1296
|
-
|
1297
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1298
|
-
return symbol.get_full_nested_name().get_id(version)
|
1299
|
-
|
1300
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1301
|
-
res = []
|
1302
|
-
res.append(transform(self.ident))
|
1303
|
-
if self.args is not None:
|
1304
|
-
res.append('(')
|
1305
|
-
first = True
|
1306
|
-
for arg in self.args:
|
1307
|
-
if not first:
|
1308
|
-
res.append(', ')
|
1309
|
-
first = False
|
1310
|
-
res.append(transform(arg))
|
1311
|
-
res.append(')')
|
1312
|
-
return ''.join(res)
|
1313
|
-
|
1314
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1315
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1316
|
-
verify_description_mode(mode)
|
1317
|
-
self.ident.describe_signature(signode, mode, env, symbol)
|
1318
|
-
if self.args is None:
|
1319
|
-
return
|
1320
|
-
paramlist = addnodes.desc_parameterlist()
|
1321
|
-
for arg in self.args:
|
1322
|
-
param = addnodes.desc_parameter('', '', noemph=True)
|
1323
|
-
arg.describe_signature(param, 'param', env, symbol=symbol)
|
1324
|
-
paramlist += param
|
1325
|
-
signode += paramlist
|
1326
|
-
|
1327
|
-
|
1328
|
-
class ASTStruct(ASTBase):
|
1329
|
-
def __init__(self, name: ASTNestedName) -> None:
|
1330
|
-
self.name = name
|
1331
|
-
|
1332
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1333
|
-
return symbol.get_full_nested_name().get_id(version)
|
1334
|
-
|
1335
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1336
|
-
return transform(self.name)
|
1337
|
-
|
1338
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1339
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1340
|
-
verify_description_mode(mode)
|
1341
|
-
self.name.describe_signature(signode, mode, env, symbol=symbol)
|
1342
|
-
|
1343
|
-
|
1344
|
-
class ASTUnion(ASTBase):
|
1345
|
-
def __init__(self, name: ASTNestedName) -> None:
|
1346
|
-
self.name = name
|
1347
|
-
|
1348
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1349
|
-
return symbol.get_full_nested_name().get_id(version)
|
1350
|
-
|
1351
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1352
|
-
return transform(self.name)
|
1353
|
-
|
1354
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1355
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1356
|
-
verify_description_mode(mode)
|
1357
|
-
self.name.describe_signature(signode, mode, env, symbol=symbol)
|
1358
|
-
|
1359
|
-
|
1360
|
-
class ASTEnum(ASTBase):
|
1361
|
-
def __init__(self, name: ASTNestedName) -> None:
|
1362
|
-
self.name = name
|
1363
|
-
|
1364
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1365
|
-
return symbol.get_full_nested_name().get_id(version)
|
1366
|
-
|
1367
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1368
|
-
return transform(self.name)
|
1369
|
-
|
1370
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1371
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1372
|
-
verify_description_mode(mode)
|
1373
|
-
self.name.describe_signature(signode, mode, env, symbol=symbol)
|
1374
|
-
|
1375
|
-
|
1376
|
-
class ASTEnumerator(ASTBase):
|
1377
|
-
def __init__(self, name: ASTNestedName, init: ASTInitializer | None,
|
1378
|
-
attrs: ASTAttributeList) -> None:
|
1379
|
-
self.name = name
|
1380
|
-
self.init = init
|
1381
|
-
self.attrs = attrs
|
1382
|
-
|
1383
|
-
def get_id(self, version: int, objectType: str, symbol: Symbol) -> str:
|
1384
|
-
return symbol.get_full_nested_name().get_id(version)
|
1385
|
-
|
1386
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1387
|
-
res = []
|
1388
|
-
res.append(transform(self.name))
|
1389
|
-
if len(self.attrs) != 0:
|
1390
|
-
res.append(' ')
|
1391
|
-
res.append(transform(self.attrs))
|
1392
|
-
if self.init:
|
1393
|
-
res.append(transform(self.init))
|
1394
|
-
return ''.join(res)
|
1395
|
-
|
1396
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1397
|
-
env: BuildEnvironment, symbol: Symbol) -> None:
|
1398
|
-
verify_description_mode(mode)
|
1399
|
-
self.name.describe_signature(signode, mode, env, symbol)
|
1400
|
-
if len(self.attrs) != 0:
|
1401
|
-
signode += addnodes.desc_sig_space()
|
1402
|
-
self.attrs.describe_signature(signode)
|
1403
|
-
if self.init:
|
1404
|
-
self.init.describe_signature(signode, 'markType', env, symbol)
|
1405
|
-
|
1406
|
-
|
1407
|
-
class ASTDeclaration(ASTBaseBase):
|
1408
|
-
def __init__(self, objectType: str, directiveType: str | None,
|
1409
|
-
declaration: DeclarationType | ASTFunctionParameter,
|
1410
|
-
semicolon: bool = False) -> None:
|
1411
|
-
self.objectType = objectType
|
1412
|
-
self.directiveType = directiveType
|
1413
|
-
self.declaration = declaration
|
1414
|
-
self.semicolon = semicolon
|
1415
|
-
|
1416
|
-
self.symbol: Symbol = None
|
1417
|
-
# set by CObject._add_enumerator_to_parent
|
1418
|
-
self.enumeratorScopedSymbol: Symbol = None
|
1419
|
-
|
1420
|
-
def clone(self) -> ASTDeclaration:
|
1421
|
-
return ASTDeclaration(self.objectType, self.directiveType,
|
1422
|
-
self.declaration.clone(), self.semicolon)
|
1423
|
-
|
1424
|
-
@property
|
1425
|
-
def name(self) -> ASTNestedName:
|
1426
|
-
decl = cast(DeclarationType, self.declaration)
|
1427
|
-
return decl.name
|
1428
|
-
|
1429
|
-
@property
|
1430
|
-
def function_params(self) -> list[ASTFunctionParameter] | None:
|
1431
|
-
if self.objectType != 'function':
|
1432
|
-
return None
|
1433
|
-
decl = cast(ASTType, self.declaration)
|
1434
|
-
return decl.function_params
|
1435
|
-
|
1436
|
-
def get_id(self, version: int, prefixed: bool = True) -> str:
|
1437
|
-
if self.objectType == 'enumerator' and self.enumeratorScopedSymbol:
|
1438
|
-
return self.enumeratorScopedSymbol.declaration.get_id(version, prefixed)
|
1439
|
-
id_ = self.declaration.get_id(version, self.objectType, self.symbol)
|
1440
|
-
if prefixed:
|
1441
|
-
return _id_prefix[version] + id_
|
1442
|
-
else:
|
1443
|
-
return id_
|
1444
|
-
|
1445
|
-
def get_newest_id(self) -> str:
|
1446
|
-
return self.get_id(_max_id, True)
|
1447
|
-
|
1448
|
-
def _stringify(self, transform: StringifyTransform) -> str:
|
1449
|
-
res = transform(self.declaration)
|
1450
|
-
if self.semicolon:
|
1451
|
-
res += ';'
|
1452
|
-
return res
|
1453
|
-
|
1454
|
-
def describe_signature(self, signode: TextElement, mode: str,
|
1455
|
-
env: BuildEnvironment, options: dict) -> None:
|
1456
|
-
verify_description_mode(mode)
|
1457
|
-
assert self.symbol
|
1458
|
-
# The caller of the domain added a desc_signature node.
|
1459
|
-
# Always enable multiline:
|
1460
|
-
signode['is_multiline'] = True
|
1461
|
-
# Put each line in a desc_signature_line node.
|
1462
|
-
mainDeclNode = addnodes.desc_signature_line()
|
1463
|
-
mainDeclNode.sphinx_line_type = 'declarator'
|
1464
|
-
mainDeclNode['add_permalink'] = not self.symbol.isRedeclaration
|
1465
|
-
signode += mainDeclNode
|
1466
|
-
|
1467
|
-
if self.objectType == 'member':
|
1468
|
-
pass
|
1469
|
-
elif self.objectType == 'function':
|
1470
|
-
pass
|
1471
|
-
elif self.objectType == 'macro':
|
1472
|
-
pass
|
1473
|
-
elif self.objectType == 'struct':
|
1474
|
-
mainDeclNode += addnodes.desc_sig_keyword('struct', 'struct')
|
1475
|
-
mainDeclNode += addnodes.desc_sig_space()
|
1476
|
-
elif self.objectType == 'union':
|
1477
|
-
mainDeclNode += addnodes.desc_sig_keyword('union', 'union')
|
1478
|
-
mainDeclNode += addnodes.desc_sig_space()
|
1479
|
-
elif self.objectType == 'enum':
|
1480
|
-
mainDeclNode += addnodes.desc_sig_keyword('enum', 'enum')
|
1481
|
-
mainDeclNode += addnodes.desc_sig_space()
|
1482
|
-
elif self.objectType == 'enumerator':
|
1483
|
-
mainDeclNode += addnodes.desc_sig_keyword('enumerator', 'enumerator')
|
1484
|
-
mainDeclNode += addnodes.desc_sig_space()
|
1485
|
-
elif self.objectType == 'type':
|
1486
|
-
decl = cast(ASTType, self.declaration)
|
1487
|
-
prefix = decl.get_type_declaration_prefix()
|
1488
|
-
mainDeclNode += addnodes.desc_sig_keyword(prefix, prefix)
|
1489
|
-
mainDeclNode += addnodes.desc_sig_space()
|
1490
|
-
else:
|
1491
|
-
raise AssertionError()
|
1492
|
-
self.declaration.describe_signature(mainDeclNode, mode, env, self.symbol)
|
1493
|
-
if self.semicolon:
|
1494
|
-
mainDeclNode += addnodes.desc_sig_punctuation(';', ';')
|
1495
|
-
|
1496
|
-
|
1497
|
-
class SymbolLookupResult:
|
1498
|
-
def __init__(self, symbols: Iterator[Symbol], parentSymbol: Symbol,
|
1499
|
-
ident: ASTIdentifier) -> None:
|
1500
|
-
self.symbols = symbols
|
1501
|
-
self.parentSymbol = parentSymbol
|
1502
|
-
self.ident = ident
|
1503
|
-
|
1504
|
-
|
1505
|
-
class LookupKey:
|
1506
|
-
def __init__(self, data: list[tuple[ASTIdentifier, str]]) -> None:
|
1507
|
-
self.data = data
|
1508
|
-
|
1509
|
-
def __str__(self) -> str:
|
1510
|
-
inner = ', '.join(f"({ident}, {id_})" for ident, id_ in self.data)
|
1511
|
-
return f'[{inner}]'
|
1512
|
-
|
1513
|
-
|
1514
|
-
class Symbol:
|
1515
|
-
debug_indent = 0
|
1516
|
-
debug_indent_string = " "
|
1517
|
-
debug_lookup = False
|
1518
|
-
debug_show_tree = False
|
1519
|
-
|
1520
|
-
def __copy__(self):
|
1521
|
-
raise AssertionError() # shouldn't happen
|
1522
|
-
|
1523
|
-
def __deepcopy__(self, memo):
|
1524
|
-
if self.parent:
|
1525
|
-
raise AssertionError() # shouldn't happen
|
1526
|
-
else:
|
1527
|
-
# the domain base class makes a copy of the initial data, which is fine
|
1528
|
-
return Symbol(None, None, None, None, None)
|
1529
|
-
|
1530
|
-
@staticmethod
|
1531
|
-
def debug_print(*args: Any) -> None:
|
1532
|
-
print(Symbol.debug_indent_string * Symbol.debug_indent, end="")
|
1533
|
-
print(*args)
|
1534
|
-
|
1535
|
-
def _assert_invariants(self) -> None:
|
1536
|
-
if not self.parent:
|
1537
|
-
# parent == None means global scope, so declaration means a parent
|
1538
|
-
assert not self.declaration
|
1539
|
-
assert not self.docname
|
1540
|
-
else:
|
1541
|
-
if self.declaration:
|
1542
|
-
assert self.docname
|
1543
|
-
|
1544
|
-
def __setattr__(self, key: str, value: Any) -> None:
|
1545
|
-
if key == "children":
|
1546
|
-
raise AssertionError()
|
1547
|
-
else:
|
1548
|
-
return super().__setattr__(key, value)
|
1549
|
-
|
1550
|
-
def __init__(
|
1551
|
-
self,
|
1552
|
-
parent: Symbol,
|
1553
|
-
ident: ASTIdentifier,
|
1554
|
-
declaration: ASTDeclaration | None,
|
1555
|
-
docname: str | None,
|
1556
|
-
line: int | None,
|
1557
|
-
) -> None:
|
1558
|
-
self.parent = parent
|
1559
|
-
# declarations in a single directive are linked together
|
1560
|
-
self.siblingAbove: Symbol = None
|
1561
|
-
self.siblingBelow: Symbol = None
|
1562
|
-
self.ident = ident
|
1563
|
-
self.declaration = declaration
|
1564
|
-
self.docname = docname
|
1565
|
-
self.line = line
|
1566
|
-
self.isRedeclaration = False
|
1567
|
-
self._assert_invariants()
|
1568
|
-
|
1569
|
-
# Remember to modify Symbol.remove if modifications to the parent change.
|
1570
|
-
self._children: list[Symbol] = []
|
1571
|
-
self._anonChildren: list[Symbol] = []
|
1572
|
-
# note: _children includes _anonChildren
|
1573
|
-
if self.parent:
|
1574
|
-
self.parent._children.append(self)
|
1575
|
-
if self.declaration:
|
1576
|
-
self.declaration.symbol = self
|
1577
|
-
|
1578
|
-
# Do symbol addition after self._children has been initialised.
|
1579
|
-
self._add_function_params()
|
1580
|
-
|
1581
|
-
def _fill_empty(self, declaration: ASTDeclaration, docname: str, line: int) -> None:
|
1582
|
-
self._assert_invariants()
|
1583
|
-
assert self.declaration is None
|
1584
|
-
assert self.docname is None
|
1585
|
-
assert self.line is None
|
1586
|
-
assert declaration is not None
|
1587
|
-
assert docname is not None
|
1588
|
-
assert line is not None
|
1589
|
-
self.declaration = declaration
|
1590
|
-
self.declaration.symbol = self
|
1591
|
-
self.docname = docname
|
1592
|
-
self.line = line
|
1593
|
-
self._assert_invariants()
|
1594
|
-
# and symbol addition should be done as well
|
1595
|
-
self._add_function_params()
|
1596
|
-
|
1597
|
-
def _add_function_params(self) -> None:
|
1598
|
-
if Symbol.debug_lookup:
|
1599
|
-
Symbol.debug_indent += 1
|
1600
|
-
Symbol.debug_print("_add_function_params:")
|
1601
|
-
# Note: we may be called from _fill_empty, so the symbols we want
|
1602
|
-
# to add may actually already be present (as empty symbols).
|
1603
|
-
|
1604
|
-
# add symbols for function parameters, if any
|
1605
|
-
if self.declaration is not None and self.declaration.function_params is not None:
|
1606
|
-
for p in self.declaration.function_params:
|
1607
|
-
if p.arg is None:
|
1608
|
-
continue
|
1609
|
-
nn = p.arg.name
|
1610
|
-
if nn is None:
|
1611
|
-
continue
|
1612
|
-
# (comparing to the template params: we have checked that we are a declaration)
|
1613
|
-
decl = ASTDeclaration('functionParam', None, p)
|
1614
|
-
assert not nn.rooted
|
1615
|
-
assert len(nn.names) == 1
|
1616
|
-
self._add_symbols(nn, decl, self.docname, self.line)
|
1617
|
-
if Symbol.debug_lookup:
|
1618
|
-
Symbol.debug_indent -= 1
|
1619
|
-
|
1620
|
-
def remove(self) -> None:
|
1621
|
-
if self.parent is None:
|
1622
|
-
return
|
1623
|
-
assert self in self.parent._children
|
1624
|
-
self.parent._children.remove(self)
|
1625
|
-
self.parent = None
|
1626
|
-
|
1627
|
-
def clear_doc(self, docname: str) -> None:
|
1628
|
-
for sChild in self._children:
|
1629
|
-
sChild.clear_doc(docname)
|
1630
|
-
if sChild.declaration and sChild.docname == docname:
|
1631
|
-
sChild.declaration = None
|
1632
|
-
sChild.docname = None
|
1633
|
-
sChild.line = None
|
1634
|
-
if sChild.siblingAbove is not None:
|
1635
|
-
sChild.siblingAbove.siblingBelow = sChild.siblingBelow
|
1636
|
-
if sChild.siblingBelow is not None:
|
1637
|
-
sChild.siblingBelow.siblingAbove = sChild.siblingAbove
|
1638
|
-
sChild.siblingAbove = None
|
1639
|
-
sChild.siblingBelow = None
|
1640
|
-
|
1641
|
-
def get_all_symbols(self) -> Iterator[Symbol]:
|
1642
|
-
yield self
|
1643
|
-
for sChild in self._children:
|
1644
|
-
yield from sChild.get_all_symbols()
|
1645
|
-
|
1646
|
-
@property
|
1647
|
-
def children(self) -> Iterator[Symbol]:
|
1648
|
-
yield from self._children
|
1649
|
-
|
1650
|
-
@property
|
1651
|
-
def children_recurse_anon(self) -> Iterator[Symbol]:
|
1652
|
-
for c in self._children:
|
1653
|
-
yield c
|
1654
|
-
if not c.ident.is_anon():
|
1655
|
-
continue
|
1656
|
-
yield from c.children_recurse_anon
|
1657
|
-
|
1658
|
-
def get_lookup_key(self) -> LookupKey:
|
1659
|
-
# The pickle files for the environment and for each document are distinct.
|
1660
|
-
# The environment has all the symbols, but the documents has xrefs that
|
1661
|
-
# must know their scope. A lookup key is essentially a specification of
|
1662
|
-
# how to find a specific symbol.
|
1663
|
-
symbols = []
|
1664
|
-
s = self
|
1665
|
-
while s.parent:
|
1666
|
-
symbols.append(s)
|
1667
|
-
s = s.parent
|
1668
|
-
symbols.reverse()
|
1669
|
-
key = []
|
1670
|
-
for s in symbols:
|
1671
|
-
if s.declaration is not None:
|
1672
|
-
# TODO: do we need the ID?
|
1673
|
-
key.append((s.ident, s.declaration.get_newest_id()))
|
1674
|
-
else:
|
1675
|
-
key.append((s.ident, None))
|
1676
|
-
return LookupKey(key)
|
1677
|
-
|
1678
|
-
def get_full_nested_name(self) -> ASTNestedName:
|
1679
|
-
symbols = []
|
1680
|
-
s = self
|
1681
|
-
while s.parent:
|
1682
|
-
symbols.append(s)
|
1683
|
-
s = s.parent
|
1684
|
-
symbols.reverse()
|
1685
|
-
names = []
|
1686
|
-
for s in symbols:
|
1687
|
-
names.append(s.ident)
|
1688
|
-
return ASTNestedName(names, rooted=False)
|
1689
|
-
|
1690
|
-
def _find_first_named_symbol(self, ident: ASTIdentifier,
|
1691
|
-
matchSelf: bool, recurseInAnon: bool) -> Symbol | None:
|
1692
|
-
# TODO: further simplification from C++ to C
|
1693
|
-
if Symbol.debug_lookup:
|
1694
|
-
Symbol.debug_print("_find_first_named_symbol ->")
|
1695
|
-
res = self._find_named_symbols(ident, matchSelf, recurseInAnon,
|
1696
|
-
searchInSiblings=False)
|
1697
|
-
try:
|
1698
|
-
return next(res)
|
1699
|
-
except StopIteration:
|
1700
|
-
return None
|
1701
|
-
|
1702
|
-
def _find_named_symbols(self, ident: ASTIdentifier,
|
1703
|
-
matchSelf: bool, recurseInAnon: bool,
|
1704
|
-
searchInSiblings: bool) -> Iterator[Symbol]:
|
1705
|
-
# TODO: further simplification from C++ to C
|
1706
|
-
if Symbol.debug_lookup:
|
1707
|
-
Symbol.debug_indent += 1
|
1708
|
-
Symbol.debug_print("_find_named_symbols:")
|
1709
|
-
Symbol.debug_indent += 1
|
1710
|
-
Symbol.debug_print("self:")
|
1711
|
-
print(self.to_string(Symbol.debug_indent + 1), end="")
|
1712
|
-
Symbol.debug_print("ident: ", ident)
|
1713
|
-
Symbol.debug_print("matchSelf: ", matchSelf)
|
1714
|
-
Symbol.debug_print("recurseInAnon: ", recurseInAnon)
|
1715
|
-
Symbol.debug_print("searchInSiblings: ", searchInSiblings)
|
1716
|
-
|
1717
|
-
def candidates() -> Generator[Symbol, None, None]:
|
1718
|
-
s = self
|
1719
|
-
if Symbol.debug_lookup:
|
1720
|
-
Symbol.debug_print("searching in self:")
|
1721
|
-
print(s.to_string(Symbol.debug_indent + 1), end="")
|
1722
|
-
while True:
|
1723
|
-
if matchSelf:
|
1724
|
-
yield s
|
1725
|
-
if recurseInAnon:
|
1726
|
-
yield from s.children_recurse_anon
|
1727
|
-
else:
|
1728
|
-
yield from s._children
|
1729
|
-
|
1730
|
-
if s.siblingAbove is None:
|
1731
|
-
break
|
1732
|
-
s = s.siblingAbove
|
1733
|
-
if Symbol.debug_lookup:
|
1734
|
-
Symbol.debug_print("searching in sibling:")
|
1735
|
-
print(s.to_string(Symbol.debug_indent + 1), end="")
|
1736
|
-
|
1737
|
-
for s in candidates():
|
1738
|
-
if Symbol.debug_lookup:
|
1739
|
-
Symbol.debug_print("candidate:")
|
1740
|
-
print(s.to_string(Symbol.debug_indent + 1), end="")
|
1741
|
-
if s.ident == ident:
|
1742
|
-
if Symbol.debug_lookup:
|
1743
|
-
Symbol.debug_indent += 1
|
1744
|
-
Symbol.debug_print("matches")
|
1745
|
-
Symbol.debug_indent -= 3
|
1746
|
-
yield s
|
1747
|
-
if Symbol.debug_lookup:
|
1748
|
-
Symbol.debug_indent += 2
|
1749
|
-
if Symbol.debug_lookup:
|
1750
|
-
Symbol.debug_indent -= 2
|
1751
|
-
|
1752
|
-
def _symbol_lookup(
|
1753
|
-
self,
|
1754
|
-
nestedName: ASTNestedName,
|
1755
|
-
onMissingQualifiedSymbol: Callable[[Symbol, ASTIdentifier], Symbol | None],
|
1756
|
-
ancestorLookupType: str | None,
|
1757
|
-
matchSelf: bool,
|
1758
|
-
recurseInAnon: bool,
|
1759
|
-
searchInSiblings: bool
|
1760
|
-
) -> SymbolLookupResult | None:
|
1761
|
-
# TODO: further simplification from C++ to C
|
1762
|
-
# ancestorLookupType: if not None, specifies the target type of the lookup
|
1763
|
-
if Symbol.debug_lookup:
|
1764
|
-
Symbol.debug_indent += 1
|
1765
|
-
Symbol.debug_print("_symbol_lookup:")
|
1766
|
-
Symbol.debug_indent += 1
|
1767
|
-
Symbol.debug_print("self:")
|
1768
|
-
print(self.to_string(Symbol.debug_indent + 1), end="")
|
1769
|
-
Symbol.debug_print("nestedName: ", nestedName)
|
1770
|
-
Symbol.debug_print("ancestorLookupType:", ancestorLookupType)
|
1771
|
-
Symbol.debug_print("matchSelf: ", matchSelf)
|
1772
|
-
Symbol.debug_print("recurseInAnon: ", recurseInAnon)
|
1773
|
-
Symbol.debug_print("searchInSiblings: ", searchInSiblings)
|
1774
|
-
|
1775
|
-
names = nestedName.names
|
1776
|
-
|
1777
|
-
# find the right starting point for lookup
|
1778
|
-
parentSymbol = self
|
1779
|
-
if nestedName.rooted:
|
1780
|
-
while parentSymbol.parent:
|
1781
|
-
parentSymbol = parentSymbol.parent
|
1782
|
-
if ancestorLookupType is not None:
|
1783
|
-
# walk up until we find the first identifier
|
1784
|
-
firstName = names[0]
|
1785
|
-
while parentSymbol.parent:
|
1786
|
-
if parentSymbol.find_identifier(firstName,
|
1787
|
-
matchSelf=matchSelf,
|
1788
|
-
recurseInAnon=recurseInAnon,
|
1789
|
-
searchInSiblings=searchInSiblings):
|
1790
|
-
break
|
1791
|
-
parentSymbol = parentSymbol.parent
|
1792
|
-
|
1793
|
-
if Symbol.debug_lookup:
|
1794
|
-
Symbol.debug_print("starting point:")
|
1795
|
-
print(parentSymbol.to_string(Symbol.debug_indent + 1), end="")
|
1796
|
-
|
1797
|
-
# and now the actual lookup
|
1798
|
-
for ident in names[:-1]:
|
1799
|
-
symbol = parentSymbol._find_first_named_symbol(
|
1800
|
-
ident, matchSelf=matchSelf, recurseInAnon=recurseInAnon)
|
1801
|
-
if symbol is None:
|
1802
|
-
symbol = onMissingQualifiedSymbol(parentSymbol, ident)
|
1803
|
-
if symbol is None:
|
1804
|
-
if Symbol.debug_lookup:
|
1805
|
-
Symbol.debug_indent -= 2
|
1806
|
-
return None
|
1807
|
-
# We have now matched part of a nested name, and need to match more
|
1808
|
-
# so even if we should matchSelf before, we definitely shouldn't
|
1809
|
-
# even more. (see also issue #2666)
|
1810
|
-
matchSelf = False
|
1811
|
-
parentSymbol = symbol
|
1812
|
-
|
1813
|
-
if Symbol.debug_lookup:
|
1814
|
-
Symbol.debug_print("handle last name from:")
|
1815
|
-
print(parentSymbol.to_string(Symbol.debug_indent + 1), end="")
|
1816
|
-
|
1817
|
-
# handle the last name
|
1818
|
-
ident = names[-1]
|
1819
|
-
|
1820
|
-
symbols = parentSymbol._find_named_symbols(
|
1821
|
-
ident, matchSelf=matchSelf,
|
1822
|
-
recurseInAnon=recurseInAnon,
|
1823
|
-
searchInSiblings=searchInSiblings)
|
1824
|
-
if Symbol.debug_lookup:
|
1825
|
-
symbols = list(symbols) # type: ignore
|
1826
|
-
Symbol.debug_indent -= 2
|
1827
|
-
return SymbolLookupResult(symbols, parentSymbol, ident)
|
1828
|
-
|
1829
|
-
def _add_symbols(
|
1830
|
-
self,
|
1831
|
-
nestedName: ASTNestedName,
|
1832
|
-
declaration: ASTDeclaration | None,
|
1833
|
-
docname: str | None,
|
1834
|
-
line: int | None,
|
1835
|
-
) -> Symbol:
|
1836
|
-
# TODO: further simplification from C++ to C
|
1837
|
-
# Used for adding a whole path of symbols, where the last may or may not
|
1838
|
-
# be an actual declaration.
|
1839
|
-
|
1840
|
-
if Symbol.debug_lookup:
|
1841
|
-
Symbol.debug_indent += 1
|
1842
|
-
Symbol.debug_print("_add_symbols:")
|
1843
|
-
Symbol.debug_indent += 1
|
1844
|
-
Symbol.debug_print("nn: ", nestedName)
|
1845
|
-
Symbol.debug_print("decl: ", declaration)
|
1846
|
-
Symbol.debug_print(f"location: {docname}:{line}")
|
1847
|
-
|
1848
|
-
def onMissingQualifiedSymbol(parentSymbol: Symbol, ident: ASTIdentifier) -> Symbol:
|
1849
|
-
if Symbol.debug_lookup:
|
1850
|
-
Symbol.debug_indent += 1
|
1851
|
-
Symbol.debug_print("_add_symbols, onMissingQualifiedSymbol:")
|
1852
|
-
Symbol.debug_indent += 1
|
1853
|
-
Symbol.debug_print("ident: ", ident)
|
1854
|
-
Symbol.debug_indent -= 2
|
1855
|
-
return Symbol(parent=parentSymbol, ident=ident,
|
1856
|
-
declaration=None, docname=None, line=None)
|
1857
|
-
|
1858
|
-
lookupResult = self._symbol_lookup(nestedName,
|
1859
|
-
onMissingQualifiedSymbol,
|
1860
|
-
ancestorLookupType=None,
|
1861
|
-
matchSelf=False,
|
1862
|
-
recurseInAnon=False,
|
1863
|
-
searchInSiblings=False)
|
1864
|
-
assert lookupResult is not None # we create symbols all the way, so that can't happen
|
1865
|
-
symbols = list(lookupResult.symbols)
|
1866
|
-
if len(symbols) == 0:
|
1867
|
-
if Symbol.debug_lookup:
|
1868
|
-
Symbol.debug_print("_add_symbols, result, no symbol:")
|
1869
|
-
Symbol.debug_indent += 1
|
1870
|
-
Symbol.debug_print("ident: ", lookupResult.ident)
|
1871
|
-
Symbol.debug_print("declaration: ", declaration)
|
1872
|
-
Symbol.debug_print(f"location: {docname}:{line}")
|
1873
|
-
Symbol.debug_indent -= 1
|
1874
|
-
symbol = Symbol(parent=lookupResult.parentSymbol,
|
1875
|
-
ident=lookupResult.ident,
|
1876
|
-
declaration=declaration,
|
1877
|
-
docname=docname, line=line)
|
1878
|
-
if Symbol.debug_lookup:
|
1879
|
-
Symbol.debug_indent -= 2
|
1880
|
-
return symbol
|
1881
|
-
|
1882
|
-
if Symbol.debug_lookup:
|
1883
|
-
Symbol.debug_print("_add_symbols, result, symbols:")
|
1884
|
-
Symbol.debug_indent += 1
|
1885
|
-
Symbol.debug_print("number symbols:", len(symbols))
|
1886
|
-
Symbol.debug_indent -= 1
|
1887
|
-
|
1888
|
-
if not declaration:
|
1889
|
-
if Symbol.debug_lookup:
|
1890
|
-
Symbol.debug_print("no declaration")
|
1891
|
-
Symbol.debug_indent -= 2
|
1892
|
-
# good, just a scope creation
|
1893
|
-
# TODO: what if we have more than one symbol?
|
1894
|
-
return symbols[0]
|
1895
|
-
|
1896
|
-
noDecl = []
|
1897
|
-
withDecl = []
|
1898
|
-
dupDecl = []
|
1899
|
-
for s in symbols:
|
1900
|
-
if s.declaration is None:
|
1901
|
-
noDecl.append(s)
|
1902
|
-
elif s.isRedeclaration:
|
1903
|
-
dupDecl.append(s)
|
1904
|
-
else:
|
1905
|
-
withDecl.append(s)
|
1906
|
-
if Symbol.debug_lookup:
|
1907
|
-
Symbol.debug_print("#noDecl: ", len(noDecl))
|
1908
|
-
Symbol.debug_print("#withDecl:", len(withDecl))
|
1909
|
-
Symbol.debug_print("#dupDecl: ", len(dupDecl))
|
1910
|
-
|
1911
|
-
# With partial builds we may start with a large symbol tree stripped of declarations.
|
1912
|
-
# Essentially any combination of noDecl, withDecl, and dupDecls seems possible.
|
1913
|
-
# TODO: make partial builds fully work. What should happen when the primary symbol gets
|
1914
|
-
# deleted, and other duplicates exist? The full document should probably be rebuild.
|
1915
|
-
|
1916
|
-
# First check if one of those with a declaration matches.
|
1917
|
-
# If it's a function, we need to compare IDs,
|
1918
|
-
# otherwise there should be only one symbol with a declaration.
|
1919
|
-
def makeCandSymbol() -> Symbol:
|
1920
|
-
if Symbol.debug_lookup:
|
1921
|
-
Symbol.debug_print("begin: creating candidate symbol")
|
1922
|
-
symbol = Symbol(parent=lookupResult.parentSymbol,
|
1923
|
-
ident=lookupResult.ident,
|
1924
|
-
declaration=declaration,
|
1925
|
-
docname=docname, line=line)
|
1926
|
-
if Symbol.debug_lookup:
|
1927
|
-
Symbol.debug_print("end: creating candidate symbol")
|
1928
|
-
return symbol
|
1929
|
-
|
1930
|
-
if len(withDecl) == 0:
|
1931
|
-
candSymbol = None
|
1932
|
-
else:
|
1933
|
-
candSymbol = makeCandSymbol()
|
1934
|
-
|
1935
|
-
def handleDuplicateDeclaration(symbol: Symbol, candSymbol: Symbol) -> None:
|
1936
|
-
if Symbol.debug_lookup:
|
1937
|
-
Symbol.debug_indent += 1
|
1938
|
-
Symbol.debug_print("redeclaration")
|
1939
|
-
Symbol.debug_indent -= 1
|
1940
|
-
Symbol.debug_indent -= 2
|
1941
|
-
# Redeclaration of the same symbol.
|
1942
|
-
# Let the new one be there, but raise an error to the client
|
1943
|
-
# so it can use the real symbol as subscope.
|
1944
|
-
# This will probably result in a duplicate id warning.
|
1945
|
-
candSymbol.isRedeclaration = True
|
1946
|
-
raise _DuplicateSymbolError(symbol, declaration)
|
1947
|
-
|
1948
|
-
if declaration.objectType != "function":
|
1949
|
-
assert len(withDecl) <= 1
|
1950
|
-
handleDuplicateDeclaration(withDecl[0], candSymbol)
|
1951
|
-
# (not reachable)
|
1952
|
-
|
1953
|
-
# a function, so compare IDs
|
1954
|
-
candId = declaration.get_newest_id()
|
1955
|
-
if Symbol.debug_lookup:
|
1956
|
-
Symbol.debug_print("candId:", candId)
|
1957
|
-
for symbol in withDecl:
|
1958
|
-
oldId = symbol.declaration.get_newest_id()
|
1959
|
-
if Symbol.debug_lookup:
|
1960
|
-
Symbol.debug_print("oldId: ", oldId)
|
1961
|
-
if candId == oldId:
|
1962
|
-
handleDuplicateDeclaration(symbol, candSymbol)
|
1963
|
-
# (not reachable)
|
1964
|
-
# no candidate symbol found with matching ID
|
1965
|
-
# if there is an empty symbol, fill that one
|
1966
|
-
if len(noDecl) == 0:
|
1967
|
-
if Symbol.debug_lookup:
|
1968
|
-
Symbol.debug_print(
|
1969
|
-
"no match, no empty, candSybmol is not None?:", candSymbol is not None,
|
1970
|
-
)
|
1971
|
-
Symbol.debug_indent -= 2
|
1972
|
-
if candSymbol is not None:
|
1973
|
-
return candSymbol
|
1974
|
-
else:
|
1975
|
-
return makeCandSymbol()
|
1976
|
-
else:
|
1977
|
-
if Symbol.debug_lookup:
|
1978
|
-
Symbol.debug_print(
|
1979
|
-
"no match, but fill an empty declaration, candSybmol is not None?:",
|
1980
|
-
candSymbol is not None)
|
1981
|
-
Symbol.debug_indent -= 2
|
1982
|
-
if candSymbol is not None:
|
1983
|
-
candSymbol.remove()
|
1984
|
-
# assert len(noDecl) == 1
|
1985
|
-
# TODO: enable assertion when we at some point find out how to do cleanup
|
1986
|
-
# for now, just take the first one, it should work fine ... right?
|
1987
|
-
symbol = noDecl[0]
|
1988
|
-
# If someone first opened the scope, and then later
|
1989
|
-
# declares it, e.g,
|
1990
|
-
# .. namespace:: Test
|
1991
|
-
# .. namespace:: nullptr
|
1992
|
-
# .. class:: Test
|
1993
|
-
symbol._fill_empty(declaration, docname, line)
|
1994
|
-
return symbol
|
1995
|
-
|
1996
|
-
def merge_with(self, other: Symbol, docnames: list[str],
|
1997
|
-
env: BuildEnvironment) -> None:
|
1998
|
-
if Symbol.debug_lookup:
|
1999
|
-
Symbol.debug_indent += 1
|
2000
|
-
Symbol.debug_print("merge_with:")
|
2001
|
-
assert other is not None
|
2002
|
-
for otherChild in other._children:
|
2003
|
-
ourChild = self._find_first_named_symbol(
|
2004
|
-
ident=otherChild.ident, matchSelf=False,
|
2005
|
-
recurseInAnon=False)
|
2006
|
-
if ourChild is None:
|
2007
|
-
# TODO: hmm, should we prune by docnames?
|
2008
|
-
self._children.append(otherChild)
|
2009
|
-
otherChild.parent = self
|
2010
|
-
otherChild._assert_invariants()
|
2011
|
-
continue
|
2012
|
-
if otherChild.declaration and otherChild.docname in docnames:
|
2013
|
-
if not ourChild.declaration:
|
2014
|
-
ourChild._fill_empty(otherChild.declaration,
|
2015
|
-
otherChild.docname, otherChild.line)
|
2016
|
-
elif ourChild.docname != otherChild.docname:
|
2017
|
-
name = str(ourChild.declaration)
|
2018
|
-
msg = __("Duplicate C declaration, also defined at %s:%s.\n"
|
2019
|
-
"Declaration is '.. c:%s:: %s'.")
|
2020
|
-
msg = msg % (ourChild.docname, ourChild.line,
|
2021
|
-
ourChild.declaration.directiveType, name)
|
2022
|
-
logger.warning(msg, location=(otherChild.docname, otherChild.line))
|
2023
|
-
else:
|
2024
|
-
# Both have declarations, and in the same docname.
|
2025
|
-
# This can apparently happen, it should be safe to
|
2026
|
-
# just ignore it, right?
|
2027
|
-
pass
|
2028
|
-
ourChild.merge_with(otherChild, docnames, env)
|
2029
|
-
if Symbol.debug_lookup:
|
2030
|
-
Symbol.debug_indent -= 1
|
2031
|
-
|
2032
|
-
def add_name(self, nestedName: ASTNestedName) -> Symbol:
|
2033
|
-
if Symbol.debug_lookup:
|
2034
|
-
Symbol.debug_indent += 1
|
2035
|
-
Symbol.debug_print("add_name:")
|
2036
|
-
res = self._add_symbols(nestedName, declaration=None, docname=None, line=None)
|
2037
|
-
if Symbol.debug_lookup:
|
2038
|
-
Symbol.debug_indent -= 1
|
2039
|
-
return res
|
2040
|
-
|
2041
|
-
def add_declaration(self, declaration: ASTDeclaration,
|
2042
|
-
docname: str, line: int) -> Symbol:
|
2043
|
-
if Symbol.debug_lookup:
|
2044
|
-
Symbol.debug_indent += 1
|
2045
|
-
Symbol.debug_print("add_declaration:")
|
2046
|
-
assert declaration is not None
|
2047
|
-
assert docname is not None
|
2048
|
-
assert line is not None
|
2049
|
-
nestedName = declaration.name
|
2050
|
-
res = self._add_symbols(nestedName, declaration, docname, line)
|
2051
|
-
if Symbol.debug_lookup:
|
2052
|
-
Symbol.debug_indent -= 1
|
2053
|
-
return res
|
2054
|
-
|
2055
|
-
def find_identifier(self, ident: ASTIdentifier,
|
2056
|
-
matchSelf: bool, recurseInAnon: bool, searchInSiblings: bool
|
2057
|
-
) -> Symbol | None:
|
2058
|
-
if Symbol.debug_lookup:
|
2059
|
-
Symbol.debug_indent += 1
|
2060
|
-
Symbol.debug_print("find_identifier:")
|
2061
|
-
Symbol.debug_indent += 1
|
2062
|
-
Symbol.debug_print("ident: ", ident)
|
2063
|
-
Symbol.debug_print("matchSelf: ", matchSelf)
|
2064
|
-
Symbol.debug_print("recurseInAnon: ", recurseInAnon)
|
2065
|
-
Symbol.debug_print("searchInSiblings:", searchInSiblings)
|
2066
|
-
print(self.to_string(Symbol.debug_indent + 1), end="")
|
2067
|
-
Symbol.debug_indent -= 2
|
2068
|
-
current = self
|
2069
|
-
while current is not None:
|
2070
|
-
if Symbol.debug_lookup:
|
2071
|
-
Symbol.debug_indent += 2
|
2072
|
-
Symbol.debug_print("trying:")
|
2073
|
-
print(current.to_string(Symbol.debug_indent + 1), end="")
|
2074
|
-
Symbol.debug_indent -= 2
|
2075
|
-
if matchSelf and current.ident == ident:
|
2076
|
-
return current
|
2077
|
-
children = current.children_recurse_anon if recurseInAnon else current._children
|
2078
|
-
for s in children:
|
2079
|
-
if s.ident == ident:
|
2080
|
-
return s
|
2081
|
-
if not searchInSiblings:
|
2082
|
-
break
|
2083
|
-
current = current.siblingAbove
|
2084
|
-
return None
|
2085
|
-
|
2086
|
-
def direct_lookup(self, key: LookupKey) -> Symbol | None:
|
2087
|
-
if Symbol.debug_lookup:
|
2088
|
-
Symbol.debug_indent += 1
|
2089
|
-
Symbol.debug_print("direct_lookup:")
|
2090
|
-
Symbol.debug_indent += 1
|
2091
|
-
s = self
|
2092
|
-
for name, id_ in key.data:
|
2093
|
-
res = None
|
2094
|
-
for cand in s._children:
|
2095
|
-
if cand.ident == name:
|
2096
|
-
res = cand
|
2097
|
-
break
|
2098
|
-
s = res
|
2099
|
-
if Symbol.debug_lookup:
|
2100
|
-
Symbol.debug_print("name: ", name)
|
2101
|
-
Symbol.debug_print("id: ", id_)
|
2102
|
-
if s is not None:
|
2103
|
-
print(s.to_string(Symbol.debug_indent + 1), end="")
|
2104
|
-
else:
|
2105
|
-
Symbol.debug_print("not found")
|
2106
|
-
if s is None:
|
2107
|
-
if Symbol.debug_lookup:
|
2108
|
-
Symbol.debug_indent -= 2
|
2109
|
-
return None
|
2110
|
-
if Symbol.debug_lookup:
|
2111
|
-
Symbol.debug_indent -= 2
|
2112
|
-
return s
|
2113
|
-
|
2114
|
-
def find_declaration(self, nestedName: ASTNestedName, typ: str,
|
2115
|
-
matchSelf: bool, recurseInAnon: bool) -> Symbol | None:
|
2116
|
-
# templateShorthand: missing template parameter lists for templates is ok
|
2117
|
-
if Symbol.debug_lookup:
|
2118
|
-
Symbol.debug_indent += 1
|
2119
|
-
Symbol.debug_print("find_declaration:")
|
2120
|
-
|
2121
|
-
def onMissingQualifiedSymbol(
|
2122
|
-
parentSymbol: Symbol,
|
2123
|
-
ident: ASTIdentifier,
|
2124
|
-
) -> Symbol | None:
|
2125
|
-
return None
|
2126
|
-
|
2127
|
-
lookupResult = self._symbol_lookup(nestedName,
|
2128
|
-
onMissingQualifiedSymbol,
|
2129
|
-
ancestorLookupType=typ,
|
2130
|
-
matchSelf=matchSelf,
|
2131
|
-
recurseInAnon=recurseInAnon,
|
2132
|
-
searchInSiblings=False)
|
2133
|
-
if Symbol.debug_lookup:
|
2134
|
-
Symbol.debug_indent -= 1
|
2135
|
-
if lookupResult is None:
|
2136
|
-
return None
|
2137
|
-
|
2138
|
-
symbols = list(lookupResult.symbols)
|
2139
|
-
if len(symbols) == 0:
|
2140
|
-
return None
|
2141
|
-
return symbols[0]
|
2142
|
-
|
2143
|
-
def to_string(self, indent: int) -> str:
|
2144
|
-
res = [Symbol.debug_indent_string * indent]
|
2145
|
-
if not self.parent:
|
2146
|
-
res.append('::')
|
2147
|
-
else:
|
2148
|
-
if self.ident:
|
2149
|
-
res.append(str(self.ident))
|
2150
|
-
else:
|
2151
|
-
res.append(str(self.declaration))
|
2152
|
-
if self.declaration:
|
2153
|
-
res.append(": ")
|
2154
|
-
if self.isRedeclaration:
|
2155
|
-
res.append('!!duplicate!! ')
|
2156
|
-
res.append(str(self.declaration))
|
2157
|
-
if self.docname:
|
2158
|
-
res.append('\t(')
|
2159
|
-
res.append(self.docname)
|
2160
|
-
res.append(')')
|
2161
|
-
res.append('\n')
|
2162
|
-
return ''.join(res)
|
2163
|
-
|
2164
|
-
def dump(self, indent: int) -> str:
|
2165
|
-
res = [self.to_string(indent)]
|
2166
|
-
for c in self._children:
|
2167
|
-
res.append(c.dump(indent + 1))
|
2168
|
-
return ''.join(res)
|
2169
|
-
|
2170
|
-
|
2171
|
-
class DefinitionParser(BaseParser):
|
2172
|
-
@property
|
2173
|
-
def language(self) -> str:
|
2174
|
-
return 'C'
|
2175
|
-
|
2176
|
-
@property
|
2177
|
-
def id_attributes(self):
|
2178
|
-
return self.config.c_id_attributes
|
2179
|
-
|
2180
|
-
@property
|
2181
|
-
def paren_attributes(self):
|
2182
|
-
return self.config.c_paren_attributes
|
2183
|
-
|
2184
|
-
def _parse_string(self) -> str | None:
|
2185
|
-
if self.current_char != '"':
|
2186
|
-
return None
|
2187
|
-
startPos = self.pos
|
2188
|
-
self.pos += 1
|
2189
|
-
escape = False
|
2190
|
-
while True:
|
2191
|
-
if self.eof:
|
2192
|
-
self.fail("Unexpected end during inside string.")
|
2193
|
-
elif self.current_char == '"' and not escape:
|
2194
|
-
self.pos += 1
|
2195
|
-
break
|
2196
|
-
elif self.current_char == '\\':
|
2197
|
-
escape = True
|
2198
|
-
else:
|
2199
|
-
escape = False
|
2200
|
-
self.pos += 1
|
2201
|
-
return self.definition[startPos:self.pos]
|
2202
|
-
|
2203
|
-
def _parse_literal(self) -> ASTLiteral | None:
|
2204
|
-
# -> integer-literal
|
2205
|
-
# | character-literal
|
2206
|
-
# | floating-literal
|
2207
|
-
# | string-literal
|
2208
|
-
# | boolean-literal -> "false" | "true"
|
2209
|
-
self.skip_ws()
|
2210
|
-
if self.skip_word('true'):
|
2211
|
-
return ASTBooleanLiteral(True)
|
2212
|
-
if self.skip_word('false'):
|
2213
|
-
return ASTBooleanLiteral(False)
|
2214
|
-
pos = self.pos
|
2215
|
-
if self.match(float_literal_re):
|
2216
|
-
self.match(float_literal_suffix_re)
|
2217
|
-
return ASTNumberLiteral(self.definition[pos:self.pos])
|
2218
|
-
for regex in [binary_literal_re, hex_literal_re,
|
2219
|
-
integer_literal_re, octal_literal_re]:
|
2220
|
-
if self.match(regex):
|
2221
|
-
self.match(integers_literal_suffix_re)
|
2222
|
-
return ASTNumberLiteral(self.definition[pos:self.pos])
|
2223
|
-
|
2224
|
-
string = self._parse_string()
|
2225
|
-
if string is not None:
|
2226
|
-
return ASTStringLiteral(string)
|
2227
|
-
|
2228
|
-
# character-literal
|
2229
|
-
if self.match(char_literal_re):
|
2230
|
-
prefix = self.last_match.group(1) # may be None when no prefix
|
2231
|
-
data = self.last_match.group(2)
|
2232
|
-
try:
|
2233
|
-
return ASTCharLiteral(prefix, data)
|
2234
|
-
except UnicodeDecodeError as e:
|
2235
|
-
self.fail("Can not handle character literal. Internal error was: %s" % e)
|
2236
|
-
except UnsupportedMultiCharacterCharLiteral:
|
2237
|
-
self.fail("Can not handle character literal"
|
2238
|
-
" resulting in multiple decoded characters.")
|
2239
|
-
return None
|
2240
|
-
|
2241
|
-
def _parse_paren_expression(self) -> ASTExpression | None:
|
2242
|
-
# "(" expression ")"
|
2243
|
-
if self.current_char != '(':
|
2244
|
-
return None
|
2245
|
-
self.pos += 1
|
2246
|
-
res = self._parse_expression()
|
2247
|
-
self.skip_ws()
|
2248
|
-
if not self.skip_string(')'):
|
2249
|
-
self.fail("Expected ')' in end of parenthesized expression.")
|
2250
|
-
return ASTParenExpr(res)
|
2251
|
-
|
2252
|
-
def _parse_primary_expression(self) -> ASTExpression | None:
|
2253
|
-
# literal
|
2254
|
-
# "(" expression ")"
|
2255
|
-
# id-expression -> we parse this with _parse_nested_name
|
2256
|
-
self.skip_ws()
|
2257
|
-
res: ASTExpression | None = self._parse_literal()
|
2258
|
-
if res is not None:
|
2259
|
-
return res
|
2260
|
-
res = self._parse_paren_expression()
|
2261
|
-
if res is not None:
|
2262
|
-
return res
|
2263
|
-
nn = self._parse_nested_name()
|
2264
|
-
if nn is not None:
|
2265
|
-
return ASTIdExpression(nn)
|
2266
|
-
return None
|
2267
|
-
|
2268
|
-
def _parse_initializer_list(self, name: str, open: str, close: str
|
2269
|
-
) -> tuple[list[ASTExpression], bool]:
|
2270
|
-
# Parse open and close with the actual initializer-list in between
|
2271
|
-
# -> initializer-clause '...'[opt]
|
2272
|
-
# | initializer-list ',' initializer-clause '...'[opt]
|
2273
|
-
# TODO: designators
|
2274
|
-
self.skip_ws()
|
2275
|
-
if not self.skip_string_and_ws(open):
|
2276
|
-
return None, None
|
2277
|
-
if self.skip_string(close):
|
2278
|
-
return [], False
|
2279
|
-
|
2280
|
-
exprs = []
|
2281
|
-
trailingComma = False
|
2282
|
-
while True:
|
2283
|
-
self.skip_ws()
|
2284
|
-
expr = self._parse_expression()
|
2285
|
-
self.skip_ws()
|
2286
|
-
exprs.append(expr)
|
2287
|
-
self.skip_ws()
|
2288
|
-
if self.skip_string(close):
|
2289
|
-
break
|
2290
|
-
if not self.skip_string_and_ws(','):
|
2291
|
-
self.fail(f"Error in {name}, expected ',' or '{close}'.")
|
2292
|
-
if self.current_char == close and close == '}':
|
2293
|
-
self.pos += 1
|
2294
|
-
trailingComma = True
|
2295
|
-
break
|
2296
|
-
return exprs, trailingComma
|
2297
|
-
|
2298
|
-
def _parse_paren_expression_list(self) -> ASTParenExprList | None:
|
2299
|
-
# -> '(' expression-list ')'
|
2300
|
-
# though, we relax it to also allow empty parens
|
2301
|
-
# as it's needed in some cases
|
2302
|
-
#
|
2303
|
-
# expression-list
|
2304
|
-
# -> initializer-list
|
2305
|
-
exprs, trailingComma = self._parse_initializer_list("parenthesized expression-list",
|
2306
|
-
'(', ')')
|
2307
|
-
if exprs is None:
|
2308
|
-
return None
|
2309
|
-
return ASTParenExprList(exprs)
|
2310
|
-
|
2311
|
-
def _parse_braced_init_list(self) -> ASTBracedInitList | None:
|
2312
|
-
# -> '{' initializer-list ','[opt] '}'
|
2313
|
-
# | '{' '}'
|
2314
|
-
exprs, trailingComma = self._parse_initializer_list("braced-init-list", '{', '}')
|
2315
|
-
if exprs is None:
|
2316
|
-
return None
|
2317
|
-
return ASTBracedInitList(exprs, trailingComma)
|
2318
|
-
|
2319
|
-
def _parse_postfix_expression(self) -> ASTPostfixExpr:
|
2320
|
-
# -> primary
|
2321
|
-
# | postfix "[" expression "]"
|
2322
|
-
# | postfix "[" braced-init-list [opt] "]"
|
2323
|
-
# | postfix "(" expression-list [opt] ")"
|
2324
|
-
# | postfix "." id-expression // taken care of in primary by nested name
|
2325
|
-
# | postfix "->" id-expression
|
2326
|
-
# | postfix "++"
|
2327
|
-
# | postfix "--"
|
2328
|
-
|
2329
|
-
prefix = self._parse_primary_expression()
|
2330
|
-
|
2331
|
-
# and now parse postfixes
|
2332
|
-
postFixes: list[ASTPostfixOp] = []
|
2333
|
-
while True:
|
2334
|
-
self.skip_ws()
|
2335
|
-
if self.skip_string_and_ws('['):
|
2336
|
-
expr = self._parse_expression()
|
2337
|
-
self.skip_ws()
|
2338
|
-
if not self.skip_string(']'):
|
2339
|
-
self.fail("Expected ']' in end of postfix expression.")
|
2340
|
-
postFixes.append(ASTPostfixArray(expr))
|
2341
|
-
continue
|
2342
|
-
if self.skip_string('->'):
|
2343
|
-
if self.skip_string('*'):
|
2344
|
-
# don't steal the arrow
|
2345
|
-
self.pos -= 3
|
2346
|
-
else:
|
2347
|
-
name = self._parse_nested_name()
|
2348
|
-
postFixes.append(ASTPostfixMemberOfPointer(name))
|
2349
|
-
continue
|
2350
|
-
if self.skip_string('++'):
|
2351
|
-
postFixes.append(ASTPostfixInc())
|
2352
|
-
continue
|
2353
|
-
if self.skip_string('--'):
|
2354
|
-
postFixes.append(ASTPostfixDec())
|
2355
|
-
continue
|
2356
|
-
lst = self._parse_paren_expression_list()
|
2357
|
-
if lst is not None:
|
2358
|
-
postFixes.append(ASTPostfixCallExpr(lst))
|
2359
|
-
continue
|
2360
|
-
break
|
2361
|
-
return ASTPostfixExpr(prefix, postFixes)
|
2362
|
-
|
2363
|
-
def _parse_unary_expression(self) -> ASTExpression:
|
2364
|
-
# -> postfix
|
2365
|
-
# | "++" cast
|
2366
|
-
# | "--" cast
|
2367
|
-
# | unary-operator cast -> (* | & | + | - | ! | ~) cast
|
2368
|
-
# The rest:
|
2369
|
-
# | "sizeof" unary
|
2370
|
-
# | "sizeof" "(" type-id ")"
|
2371
|
-
# | "alignof" "(" type-id ")"
|
2372
|
-
self.skip_ws()
|
2373
|
-
for op in _expression_unary_ops:
|
2374
|
-
# TODO: hmm, should we be able to backtrack here?
|
2375
|
-
if op[0] in 'cn':
|
2376
|
-
res = self.skip_word(op)
|
2377
|
-
else:
|
2378
|
-
res = self.skip_string(op)
|
2379
|
-
if res:
|
2380
|
-
expr = self._parse_cast_expression()
|
2381
|
-
return ASTUnaryOpExpr(op, expr)
|
2382
|
-
if self.skip_word_and_ws('sizeof'):
|
2383
|
-
if self.skip_string_and_ws('('):
|
2384
|
-
typ = self._parse_type(named=False)
|
2385
|
-
self.skip_ws()
|
2386
|
-
if not self.skip_string(')'):
|
2387
|
-
self.fail("Expecting ')' to end 'sizeof'.")
|
2388
|
-
return ASTSizeofType(typ)
|
2389
|
-
expr = self._parse_unary_expression()
|
2390
|
-
return ASTSizeofExpr(expr)
|
2391
|
-
if self.skip_word_and_ws('alignof'):
|
2392
|
-
if not self.skip_string_and_ws('('):
|
2393
|
-
self.fail("Expecting '(' after 'alignof'.")
|
2394
|
-
typ = self._parse_type(named=False)
|
2395
|
-
self.skip_ws()
|
2396
|
-
if not self.skip_string(')'):
|
2397
|
-
self.fail("Expecting ')' to end 'alignof'.")
|
2398
|
-
return ASTAlignofExpr(typ)
|
2399
|
-
return self._parse_postfix_expression()
|
2400
|
-
|
2401
|
-
def _parse_cast_expression(self) -> ASTExpression:
|
2402
|
-
# -> unary | "(" type-id ")" cast
|
2403
|
-
pos = self.pos
|
2404
|
-
self.skip_ws()
|
2405
|
-
if self.skip_string('('):
|
2406
|
-
try:
|
2407
|
-
typ = self._parse_type(False)
|
2408
|
-
if not self.skip_string(')'):
|
2409
|
-
self.fail("Expected ')' in cast expression.")
|
2410
|
-
expr = self._parse_cast_expression()
|
2411
|
-
return ASTCastExpr(typ, expr)
|
2412
|
-
except DefinitionError as exCast:
|
2413
|
-
self.pos = pos
|
2414
|
-
try:
|
2415
|
-
return self._parse_unary_expression()
|
2416
|
-
except DefinitionError as exUnary:
|
2417
|
-
errs = []
|
2418
|
-
errs.append((exCast, "If type cast expression"))
|
2419
|
-
errs.append((exUnary, "If unary expression"))
|
2420
|
-
raise self._make_multi_error(errs,
|
2421
|
-
"Error in cast expression.") from exUnary
|
2422
|
-
else:
|
2423
|
-
return self._parse_unary_expression()
|
2424
|
-
|
2425
|
-
def _parse_logical_or_expression(self) -> ASTExpression:
|
2426
|
-
# logical-or = logical-and ||
|
2427
|
-
# logical-and = inclusive-or &&
|
2428
|
-
# inclusive-or = exclusive-or |
|
2429
|
-
# exclusive-or = and ^
|
2430
|
-
# and = equality &
|
2431
|
-
# equality = relational ==, !=
|
2432
|
-
# relational = shift <, >, <=, >=
|
2433
|
-
# shift = additive <<, >>
|
2434
|
-
# additive = multiplicative +, -
|
2435
|
-
# multiplicative = pm *, /, %
|
2436
|
-
# pm = cast .*, ->*
|
2437
|
-
def _parse_bin_op_expr(self, opId):
|
2438
|
-
if opId + 1 == len(_expression_bin_ops):
|
2439
|
-
def parser() -> ASTExpression:
|
2440
|
-
return self._parse_cast_expression()
|
2441
|
-
else:
|
2442
|
-
def parser() -> ASTExpression:
|
2443
|
-
return _parse_bin_op_expr(self, opId + 1)
|
2444
|
-
exprs = []
|
2445
|
-
ops = []
|
2446
|
-
exprs.append(parser())
|
2447
|
-
while True:
|
2448
|
-
self.skip_ws()
|
2449
|
-
pos = self.pos
|
2450
|
-
oneMore = False
|
2451
|
-
for op in _expression_bin_ops[opId]:
|
2452
|
-
if op[0] in 'abcnox':
|
2453
|
-
if not self.skip_word(op):
|
2454
|
-
continue
|
2455
|
-
else:
|
2456
|
-
if not self.skip_string(op):
|
2457
|
-
continue
|
2458
|
-
if op == '&' and self.current_char == '&':
|
2459
|
-
# don't split the && 'token'
|
2460
|
-
self.pos -= 1
|
2461
|
-
# and btw. && has lower precedence, so we are done
|
2462
|
-
break
|
2463
|
-
try:
|
2464
|
-
expr = parser()
|
2465
|
-
exprs.append(expr)
|
2466
|
-
ops.append(op)
|
2467
|
-
oneMore = True
|
2468
|
-
break
|
2469
|
-
except DefinitionError:
|
2470
|
-
self.pos = pos
|
2471
|
-
if not oneMore:
|
2472
|
-
break
|
2473
|
-
return ASTBinOpExpr(exprs, ops)
|
2474
|
-
return _parse_bin_op_expr(self, 0)
|
2475
|
-
|
2476
|
-
def _parse_conditional_expression_tail(self, orExprHead: Any) -> ASTExpression | None:
|
2477
|
-
# -> "?" expression ":" assignment-expression
|
2478
|
-
return None
|
2479
|
-
|
2480
|
-
def _parse_assignment_expression(self) -> ASTExpression:
|
2481
|
-
# -> conditional-expression
|
2482
|
-
# | logical-or-expression assignment-operator initializer-clause
|
2483
|
-
# -> conditional-expression ->
|
2484
|
-
# logical-or-expression
|
2485
|
-
# | logical-or-expression "?" expression ":" assignment-expression
|
2486
|
-
# | logical-or-expression assignment-operator initializer-clause
|
2487
|
-
exprs = []
|
2488
|
-
ops = []
|
2489
|
-
orExpr = self._parse_logical_or_expression()
|
2490
|
-
exprs.append(orExpr)
|
2491
|
-
# TODO: handle ternary with _parse_conditional_expression_tail
|
2492
|
-
while True:
|
2493
|
-
oneMore = False
|
2494
|
-
self.skip_ws()
|
2495
|
-
for op in _expression_assignment_ops:
|
2496
|
-
if op[0] in 'abcnox':
|
2497
|
-
if not self.skip_word(op):
|
2498
|
-
continue
|
2499
|
-
else:
|
2500
|
-
if not self.skip_string(op):
|
2501
|
-
continue
|
2502
|
-
expr = self._parse_logical_or_expression()
|
2503
|
-
exprs.append(expr)
|
2504
|
-
ops.append(op)
|
2505
|
-
oneMore = True
|
2506
|
-
if not oneMore:
|
2507
|
-
break
|
2508
|
-
return ASTAssignmentExpr(exprs, ops)
|
2509
|
-
|
2510
|
-
def _parse_constant_expression(self) -> ASTExpression:
|
2511
|
-
# -> conditional-expression
|
2512
|
-
orExpr = self._parse_logical_or_expression()
|
2513
|
-
# TODO: use _parse_conditional_expression_tail
|
2514
|
-
return orExpr
|
2515
|
-
|
2516
|
-
def _parse_expression(self) -> ASTExpression:
|
2517
|
-
# -> assignment-expression
|
2518
|
-
# | expression "," assignment-expression
|
2519
|
-
# TODO: actually parse the second production
|
2520
|
-
return self._parse_assignment_expression()
|
2521
|
-
|
2522
|
-
def _parse_expression_fallback(
|
2523
|
-
self, end: list[str],
|
2524
|
-
parser: Callable[[], ASTExpression],
|
2525
|
-
allow: bool = True) -> ASTExpression:
|
2526
|
-
# Stupidly "parse" an expression.
|
2527
|
-
# 'end' should be a list of characters which ends the expression.
|
2528
|
-
|
2529
|
-
# first try to use the provided parser
|
2530
|
-
prevPos = self.pos
|
2531
|
-
try:
|
2532
|
-
return parser()
|
2533
|
-
except DefinitionError as e:
|
2534
|
-
# some places (e.g., template parameters) we really don't want to use fallback,
|
2535
|
-
# and for testing we may want to globally disable it
|
2536
|
-
if not allow or not self.allowFallbackExpressionParsing:
|
2537
|
-
raise
|
2538
|
-
self.warn("Parsing of expression failed. Using fallback parser."
|
2539
|
-
" Error was:\n%s" % e)
|
2540
|
-
self.pos = prevPos
|
2541
|
-
# and then the fallback scanning
|
2542
|
-
assert end is not None
|
2543
|
-
self.skip_ws()
|
2544
|
-
startPos = self.pos
|
2545
|
-
if self.match(_string_re):
|
2546
|
-
value = self.matched_text
|
2547
|
-
else:
|
2548
|
-
# TODO: add handling of more bracket-like things, and quote handling
|
2549
|
-
brackets = {'(': ')', '{': '}', '[': ']'}
|
2550
|
-
symbols: list[str] = []
|
2551
|
-
while not self.eof:
|
2552
|
-
if (len(symbols) == 0 and self.current_char in end):
|
2553
|
-
break
|
2554
|
-
if self.current_char in brackets:
|
2555
|
-
symbols.append(brackets[self.current_char])
|
2556
|
-
elif len(symbols) > 0 and self.current_char == symbols[-1]:
|
2557
|
-
symbols.pop()
|
2558
|
-
self.pos += 1
|
2559
|
-
if len(end) > 0 and self.eof:
|
2560
|
-
self.fail("Could not find end of expression starting at %d."
|
2561
|
-
% startPos)
|
2562
|
-
value = self.definition[startPos:self.pos].strip()
|
2563
|
-
return ASTFallbackExpr(value.strip())
|
2564
|
-
|
2565
|
-
def _parse_nested_name(self) -> ASTNestedName:
|
2566
|
-
names: list[Any] = []
|
2567
|
-
|
2568
|
-
self.skip_ws()
|
2569
|
-
rooted = False
|
2570
|
-
if self.skip_string('.'):
|
2571
|
-
rooted = True
|
2572
|
-
while 1:
|
2573
|
-
self.skip_ws()
|
2574
|
-
if not self.match(identifier_re):
|
2575
|
-
self.fail("Expected identifier in nested name.")
|
2576
|
-
identifier = self.matched_text
|
2577
|
-
# make sure there isn't a keyword
|
2578
|
-
if identifier in _keywords:
|
2579
|
-
self.fail("Expected identifier in nested name, "
|
2580
|
-
"got keyword: %s" % identifier)
|
2581
|
-
if self.matched_text in self.config.c_extra_keywords:
|
2582
|
-
msg = "Expected identifier, got user-defined keyword: %s." \
|
2583
|
-
+ " Remove it from c_extra_keywords to allow it as identifier.\n" \
|
2584
|
-
+ "Currently c_extra_keywords is %s."
|
2585
|
-
self.fail(msg % (self.matched_text,
|
2586
|
-
str(self.config.c_extra_keywords)))
|
2587
|
-
ident = ASTIdentifier(identifier)
|
2588
|
-
names.append(ident)
|
2589
|
-
|
2590
|
-
self.skip_ws()
|
2591
|
-
if not self.skip_string('.'):
|
2592
|
-
break
|
2593
|
-
return ASTNestedName(names, rooted)
|
2594
|
-
|
2595
|
-
def _parse_simple_type_specifier(self) -> str | None:
|
2596
|
-
if self.match(_simple_type_specifiers_re):
|
2597
|
-
return self.matched_text
|
2598
|
-
for t in ('bool', 'complex', 'imaginary'):
|
2599
|
-
if t in self.config.c_extra_keywords:
|
2600
|
-
if self.skip_word(t):
|
2601
|
-
return t
|
2602
|
-
return None
|
2603
|
-
|
2604
|
-
def _parse_simple_type_specifiers(self) -> ASTTrailingTypeSpecFundamental | None:
|
2605
|
-
names: list[str] = []
|
2606
|
-
|
2607
|
-
self.skip_ws()
|
2608
|
-
while True:
|
2609
|
-
t = self._parse_simple_type_specifier()
|
2610
|
-
if t is None:
|
2611
|
-
break
|
2612
|
-
names.append(t)
|
2613
|
-
self.skip_ws()
|
2614
|
-
if len(names) == 0:
|
2615
|
-
return None
|
2616
|
-
return ASTTrailingTypeSpecFundamental(names)
|
2617
|
-
|
2618
|
-
def _parse_trailing_type_spec(self) -> ASTTrailingTypeSpec:
|
2619
|
-
# fundamental types, https://en.cppreference.com/w/c/language/type
|
2620
|
-
# and extensions
|
2621
|
-
self.skip_ws()
|
2622
|
-
res = self._parse_simple_type_specifiers()
|
2623
|
-
if res is not None:
|
2624
|
-
return res
|
2625
|
-
|
2626
|
-
# prefixed
|
2627
|
-
prefix = None
|
2628
|
-
self.skip_ws()
|
2629
|
-
for k in ('struct', 'enum', 'union'):
|
2630
|
-
if self.skip_word_and_ws(k):
|
2631
|
-
prefix = k
|
2632
|
-
break
|
2633
|
-
|
2634
|
-
nestedName = self._parse_nested_name()
|
2635
|
-
return ASTTrailingTypeSpecName(prefix, nestedName)
|
2636
|
-
|
2637
|
-
def _parse_parameters(self, paramMode: str) -> ASTParameters | None:
|
2638
|
-
self.skip_ws()
|
2639
|
-
if not self.skip_string('('):
|
2640
|
-
if paramMode == 'function':
|
2641
|
-
self.fail('Expecting "(" in parameters.')
|
2642
|
-
else:
|
2643
|
-
return None
|
2644
|
-
|
2645
|
-
args = []
|
2646
|
-
self.skip_ws()
|
2647
|
-
if not self.skip_string(')'):
|
2648
|
-
while 1:
|
2649
|
-
self.skip_ws()
|
2650
|
-
if self.skip_string('...'):
|
2651
|
-
args.append(ASTFunctionParameter(None, True))
|
2652
|
-
self.skip_ws()
|
2653
|
-
if not self.skip_string(')'):
|
2654
|
-
self.fail('Expected ")" after "..." in parameters.')
|
2655
|
-
break
|
2656
|
-
# note: it seems that function arguments can always be named,
|
2657
|
-
# even in function pointers and similar.
|
2658
|
-
arg = self._parse_type_with_init(outer=None, named='single')
|
2659
|
-
# TODO: parse default parameters # TODO: didn't we just do that?
|
2660
|
-
args.append(ASTFunctionParameter(arg))
|
2661
|
-
|
2662
|
-
self.skip_ws()
|
2663
|
-
if self.skip_string(','):
|
2664
|
-
continue
|
2665
|
-
elif self.skip_string(')'):
|
2666
|
-
break
|
2667
|
-
else:
|
2668
|
-
self.fail(
|
2669
|
-
'Expecting "," or ")" in parameters, '
|
2670
|
-
'got "%s".' % self.current_char)
|
2671
|
-
|
2672
|
-
attrs = self._parse_attribute_list()
|
2673
|
-
return ASTParameters(args, attrs)
|
2674
|
-
|
2675
|
-
def _parse_decl_specs_simple(
|
2676
|
-
self, outer: str | None, typed: bool
|
2677
|
-
) -> ASTDeclSpecsSimple:
|
2678
|
-
"""Just parse the simple ones."""
|
2679
|
-
storage = None
|
2680
|
-
threadLocal = None
|
2681
|
-
inline = None
|
2682
|
-
restrict = None
|
2683
|
-
volatile = None
|
2684
|
-
const = None
|
2685
|
-
attrs = []
|
2686
|
-
while 1: # accept any permutation of a subset of some decl-specs
|
2687
|
-
self.skip_ws()
|
2688
|
-
if not storage:
|
2689
|
-
if outer == 'member':
|
2690
|
-
if self.skip_word('auto'):
|
2691
|
-
storage = 'auto'
|
2692
|
-
continue
|
2693
|
-
if self.skip_word('register'):
|
2694
|
-
storage = 'register'
|
2695
|
-
continue
|
2696
|
-
if outer in ('member', 'function'):
|
2697
|
-
if self.skip_word('static'):
|
2698
|
-
storage = 'static'
|
2699
|
-
continue
|
2700
|
-
if self.skip_word('extern'):
|
2701
|
-
storage = 'extern'
|
2702
|
-
continue
|
2703
|
-
if outer == 'member' and not threadLocal:
|
2704
|
-
if self.skip_word('thread_local'):
|
2705
|
-
threadLocal = 'thread_local'
|
2706
|
-
continue
|
2707
|
-
if self.skip_word('_Thread_local'):
|
2708
|
-
threadLocal = '_Thread_local'
|
2709
|
-
continue
|
2710
|
-
if outer == 'function' and not inline:
|
2711
|
-
inline = self.skip_word('inline')
|
2712
|
-
if inline:
|
2713
|
-
continue
|
2714
|
-
|
2715
|
-
if not restrict and typed:
|
2716
|
-
restrict = self.skip_word('restrict')
|
2717
|
-
if restrict:
|
2718
|
-
continue
|
2719
|
-
if not volatile and typed:
|
2720
|
-
volatile = self.skip_word('volatile')
|
2721
|
-
if volatile:
|
2722
|
-
continue
|
2723
|
-
if not const and typed:
|
2724
|
-
const = self.skip_word('const')
|
2725
|
-
if const:
|
2726
|
-
continue
|
2727
|
-
attr = self._parse_attribute()
|
2728
|
-
if attr:
|
2729
|
-
attrs.append(attr)
|
2730
|
-
continue
|
2731
|
-
break
|
2732
|
-
return ASTDeclSpecsSimple(storage, threadLocal, inline,
|
2733
|
-
restrict, volatile, const, ASTAttributeList(attrs))
|
2734
|
-
|
2735
|
-
def _parse_decl_specs(self, outer: str | None, typed: bool = True) -> ASTDeclSpecs:
|
2736
|
-
if outer:
|
2737
|
-
if outer not in ('type', 'member', 'function'):
|
2738
|
-
raise Exception('Internal error, unknown outer "%s".' % outer)
|
2739
|
-
leftSpecs = self._parse_decl_specs_simple(outer, typed)
|
2740
|
-
rightSpecs = None
|
2741
|
-
|
2742
|
-
if typed:
|
2743
|
-
trailing = self._parse_trailing_type_spec()
|
2744
|
-
rightSpecs = self._parse_decl_specs_simple(outer, typed)
|
2745
|
-
else:
|
2746
|
-
trailing = None
|
2747
|
-
return ASTDeclSpecs(outer, leftSpecs, rightSpecs, trailing)
|
2748
|
-
|
2749
|
-
def _parse_declarator_name_suffix(
|
2750
|
-
self, named: bool | str, paramMode: str, typed: bool
|
2751
|
-
) -> ASTDeclarator:
|
2752
|
-
assert named in (True, False, 'single')
|
2753
|
-
# now we should parse the name, and then suffixes
|
2754
|
-
if named == 'single':
|
2755
|
-
if self.match(identifier_re):
|
2756
|
-
if self.matched_text in _keywords:
|
2757
|
-
self.fail("Expected identifier, "
|
2758
|
-
"got keyword: %s" % self.matched_text)
|
2759
|
-
if self.matched_text in self.config.c_extra_keywords:
|
2760
|
-
msg = "Expected identifier, got user-defined keyword: %s." \
|
2761
|
-
+ " Remove it from c_extra_keywords to allow it as identifier.\n" \
|
2762
|
-
+ "Currently c_extra_keywords is %s."
|
2763
|
-
self.fail(msg % (self.matched_text,
|
2764
|
-
str(self.config.c_extra_keywords)))
|
2765
|
-
identifier = ASTIdentifier(self.matched_text)
|
2766
|
-
declId = ASTNestedName([identifier], rooted=False)
|
2767
|
-
else:
|
2768
|
-
declId = None
|
2769
|
-
elif named:
|
2770
|
-
declId = self._parse_nested_name()
|
2771
|
-
else:
|
2772
|
-
declId = None
|
2773
|
-
arrayOps = []
|
2774
|
-
while 1:
|
2775
|
-
self.skip_ws()
|
2776
|
-
if typed and self.skip_string('['):
|
2777
|
-
self.skip_ws()
|
2778
|
-
static = False
|
2779
|
-
const = False
|
2780
|
-
volatile = False
|
2781
|
-
restrict = False
|
2782
|
-
while True:
|
2783
|
-
if not static:
|
2784
|
-
if self.skip_word_and_ws('static'):
|
2785
|
-
static = True
|
2786
|
-
continue
|
2787
|
-
if not const:
|
2788
|
-
if self.skip_word_and_ws('const'):
|
2789
|
-
const = True
|
2790
|
-
continue
|
2791
|
-
if not volatile:
|
2792
|
-
if self.skip_word_and_ws('volatile'):
|
2793
|
-
volatile = True
|
2794
|
-
continue
|
2795
|
-
if not restrict:
|
2796
|
-
if self.skip_word_and_ws('restrict'):
|
2797
|
-
restrict = True
|
2798
|
-
continue
|
2799
|
-
break
|
2800
|
-
vla = False if static else self.skip_string_and_ws('*')
|
2801
|
-
if vla:
|
2802
|
-
if not self.skip_string(']'):
|
2803
|
-
self.fail("Expected ']' in end of array operator.")
|
2804
|
-
size = None
|
2805
|
-
else:
|
2806
|
-
if self.skip_string(']'):
|
2807
|
-
size = None
|
2808
|
-
else:
|
2809
|
-
|
2810
|
-
def parser():
|
2811
|
-
return self._parse_expression()
|
2812
|
-
size = self._parse_expression_fallback([']'], parser)
|
2813
|
-
self.skip_ws()
|
2814
|
-
if not self.skip_string(']'):
|
2815
|
-
self.fail("Expected ']' in end of array operator.")
|
2816
|
-
arrayOps.append(ASTArray(static, const, volatile, restrict, vla, size))
|
2817
|
-
else:
|
2818
|
-
break
|
2819
|
-
param = self._parse_parameters(paramMode)
|
2820
|
-
if param is None and len(arrayOps) == 0:
|
2821
|
-
# perhaps a bit-field
|
2822
|
-
if named and paramMode == 'type' and typed:
|
2823
|
-
self.skip_ws()
|
2824
|
-
if self.skip_string(':'):
|
2825
|
-
size = self._parse_constant_expression()
|
2826
|
-
return ASTDeclaratorNameBitField(declId=declId, size=size)
|
2827
|
-
return ASTDeclaratorNameParam(declId=declId, arrayOps=arrayOps,
|
2828
|
-
param=param)
|
2829
|
-
|
2830
|
-
def _parse_declarator(self, named: bool | str, paramMode: str,
|
2831
|
-
typed: bool = True) -> ASTDeclarator:
|
2832
|
-
# 'typed' here means 'parse return type stuff'
|
2833
|
-
if paramMode not in ('type', 'function'):
|
2834
|
-
raise Exception(
|
2835
|
-
"Internal error, unknown paramMode '%s'." % paramMode)
|
2836
|
-
prevErrors = []
|
2837
|
-
self.skip_ws()
|
2838
|
-
if typed and self.skip_string('*'):
|
2839
|
-
self.skip_ws()
|
2840
|
-
restrict = False
|
2841
|
-
volatile = False
|
2842
|
-
const = False
|
2843
|
-
attrs = []
|
2844
|
-
while 1:
|
2845
|
-
if not restrict:
|
2846
|
-
restrict = self.skip_word_and_ws('restrict')
|
2847
|
-
if restrict:
|
2848
|
-
continue
|
2849
|
-
if not volatile:
|
2850
|
-
volatile = self.skip_word_and_ws('volatile')
|
2851
|
-
if volatile:
|
2852
|
-
continue
|
2853
|
-
if not const:
|
2854
|
-
const = self.skip_word_and_ws('const')
|
2855
|
-
if const:
|
2856
|
-
continue
|
2857
|
-
attr = self._parse_attribute()
|
2858
|
-
if attr is not None:
|
2859
|
-
attrs.append(attr)
|
2860
|
-
continue
|
2861
|
-
break
|
2862
|
-
next = self._parse_declarator(named, paramMode, typed)
|
2863
|
-
return ASTDeclaratorPtr(next=next,
|
2864
|
-
restrict=restrict, volatile=volatile, const=const,
|
2865
|
-
attrs=ASTAttributeList(attrs))
|
2866
|
-
if typed and self.current_char == '(': # note: peeking, not skipping
|
2867
|
-
# maybe this is the beginning of params, try that first,
|
2868
|
-
# otherwise assume it's noptr->declarator > ( ptr-declarator )
|
2869
|
-
pos = self.pos
|
2870
|
-
try:
|
2871
|
-
# assume this is params
|
2872
|
-
res = self._parse_declarator_name_suffix(named, paramMode,
|
2873
|
-
typed)
|
2874
|
-
return res
|
2875
|
-
except DefinitionError as exParamQual:
|
2876
|
-
msg = "If declarator-id with parameters"
|
2877
|
-
if paramMode == 'function':
|
2878
|
-
msg += " (e.g., 'void f(int arg)')"
|
2879
|
-
prevErrors.append((exParamQual, msg))
|
2880
|
-
self.pos = pos
|
2881
|
-
try:
|
2882
|
-
assert self.current_char == '('
|
2883
|
-
self.skip_string('(')
|
2884
|
-
# TODO: hmm, if there is a name, it must be in inner, right?
|
2885
|
-
# TODO: hmm, if there must be parameters, they must b
|
2886
|
-
# inside, right?
|
2887
|
-
inner = self._parse_declarator(named, paramMode, typed)
|
2888
|
-
if not self.skip_string(')'):
|
2889
|
-
self.fail("Expected ')' in \"( ptr-declarator )\"")
|
2890
|
-
next = self._parse_declarator(named=False,
|
2891
|
-
paramMode="type",
|
2892
|
-
typed=typed)
|
2893
|
-
return ASTDeclaratorParen(inner=inner, next=next)
|
2894
|
-
except DefinitionError as exNoPtrParen:
|
2895
|
-
self.pos = pos
|
2896
|
-
msg = "If parenthesis in noptr-declarator"
|
2897
|
-
if paramMode == 'function':
|
2898
|
-
msg += " (e.g., 'void (*f(int arg))(double)')"
|
2899
|
-
prevErrors.append((exNoPtrParen, msg))
|
2900
|
-
header = "Error in declarator"
|
2901
|
-
raise self._make_multi_error(prevErrors, header) from exNoPtrParen
|
2902
|
-
pos = self.pos
|
2903
|
-
try:
|
2904
|
-
return self._parse_declarator_name_suffix(named, paramMode, typed)
|
2905
|
-
except DefinitionError as e:
|
2906
|
-
self.pos = pos
|
2907
|
-
prevErrors.append((e, "If declarator-id"))
|
2908
|
-
header = "Error in declarator or parameters"
|
2909
|
-
raise self._make_multi_error(prevErrors, header) from e
|
2910
|
-
|
2911
|
-
def _parse_initializer(self, outer: str | None = None, allowFallback: bool = True
|
2912
|
-
) -> ASTInitializer | None:
|
2913
|
-
self.skip_ws()
|
2914
|
-
if outer == 'member' and False: # NoQA: SIM223 # TODO
|
2915
|
-
bracedInit = self._parse_braced_init_list()
|
2916
|
-
if bracedInit is not None:
|
2917
|
-
return ASTInitializer(bracedInit, hasAssign=False)
|
2918
|
-
|
2919
|
-
if not self.skip_string('='):
|
2920
|
-
return None
|
2921
|
-
|
2922
|
-
bracedInit = self._parse_braced_init_list()
|
2923
|
-
if bracedInit is not None:
|
2924
|
-
return ASTInitializer(bracedInit)
|
2925
|
-
|
2926
|
-
if outer == 'member':
|
2927
|
-
fallbackEnd: list[str] = []
|
2928
|
-
elif outer is None: # function parameter
|
2929
|
-
fallbackEnd = [',', ')']
|
2930
|
-
else:
|
2931
|
-
self.fail("Internal error, initializer for outer '%s' not "
|
2932
|
-
"implemented." % outer)
|
2933
|
-
|
2934
|
-
def parser():
|
2935
|
-
return self._parse_assignment_expression()
|
2936
|
-
|
2937
|
-
value = self._parse_expression_fallback(fallbackEnd, parser, allow=allowFallback)
|
2938
|
-
return ASTInitializer(value)
|
2939
|
-
|
2940
|
-
def _parse_type(self, named: bool | str, outer: str | None = None) -> ASTType:
|
2941
|
-
"""
|
2942
|
-
named=False|'single'|True: 'single' is e.g., for function objects which
|
2943
|
-
doesn't need to name the arguments, but otherwise is a single name
|
2944
|
-
"""
|
2945
|
-
if outer: # always named
|
2946
|
-
if outer not in ('type', 'member', 'function'):
|
2947
|
-
raise Exception('Internal error, unknown outer "%s".' % outer)
|
2948
|
-
assert named
|
2949
|
-
|
2950
|
-
if outer == 'type':
|
2951
|
-
# We allow type objects to just be a name.
|
2952
|
-
prevErrors = []
|
2953
|
-
startPos = self.pos
|
2954
|
-
# first try without the type
|
2955
|
-
try:
|
2956
|
-
declSpecs = self._parse_decl_specs(outer=outer, typed=False)
|
2957
|
-
decl = self._parse_declarator(named=True, paramMode=outer,
|
2958
|
-
typed=False)
|
2959
|
-
self.assert_end(allowSemicolon=True)
|
2960
|
-
except DefinitionError as exUntyped:
|
2961
|
-
desc = "If just a name"
|
2962
|
-
prevErrors.append((exUntyped, desc))
|
2963
|
-
self.pos = startPos
|
2964
|
-
try:
|
2965
|
-
declSpecs = self._parse_decl_specs(outer=outer)
|
2966
|
-
decl = self._parse_declarator(named=True, paramMode=outer)
|
2967
|
-
except DefinitionError as exTyped:
|
2968
|
-
self.pos = startPos
|
2969
|
-
desc = "If typedef-like declaration"
|
2970
|
-
prevErrors.append((exTyped, desc))
|
2971
|
-
# Retain the else branch for easier debugging.
|
2972
|
-
# TODO: it would be nice to save the previous stacktrace
|
2973
|
-
# and output it here.
|
2974
|
-
if True:
|
2975
|
-
header = "Type must be either just a name or a "
|
2976
|
-
header += "typedef-like declaration."
|
2977
|
-
raise self._make_multi_error(prevErrors, header) from exTyped
|
2978
|
-
else:
|
2979
|
-
# For testing purposes.
|
2980
|
-
# do it again to get the proper traceback (how do you
|
2981
|
-
# reliably save a traceback when an exception is
|
2982
|
-
# constructed?)
|
2983
|
-
self.pos = startPos
|
2984
|
-
typed = True
|
2985
|
-
declSpecs = self._parse_decl_specs(outer=outer, typed=typed)
|
2986
|
-
decl = self._parse_declarator(named=True, paramMode=outer,
|
2987
|
-
typed=typed)
|
2988
|
-
elif outer == 'function':
|
2989
|
-
declSpecs = self._parse_decl_specs(outer=outer)
|
2990
|
-
decl = self._parse_declarator(named=True, paramMode=outer)
|
2991
|
-
else:
|
2992
|
-
paramMode = 'type'
|
2993
|
-
if outer == 'member': # i.e., member
|
2994
|
-
named = True
|
2995
|
-
declSpecs = self._parse_decl_specs(outer=outer)
|
2996
|
-
decl = self._parse_declarator(named=named, paramMode=paramMode)
|
2997
|
-
return ASTType(declSpecs, decl)
|
2998
|
-
|
2999
|
-
def _parse_type_with_init(self, named: bool | str, outer: str | None) -> ASTTypeWithInit:
|
3000
|
-
if outer:
|
3001
|
-
assert outer in ('type', 'member', 'function')
|
3002
|
-
type = self._parse_type(outer=outer, named=named)
|
3003
|
-
init = self._parse_initializer(outer=outer)
|
3004
|
-
return ASTTypeWithInit(type, init)
|
3005
|
-
|
3006
|
-
def _parse_macro(self) -> ASTMacro:
|
3007
|
-
self.skip_ws()
|
3008
|
-
ident = self._parse_nested_name()
|
3009
|
-
if ident is None:
|
3010
|
-
self.fail("Expected identifier in macro definition.")
|
3011
|
-
self.skip_ws()
|
3012
|
-
if not self.skip_string_and_ws('('):
|
3013
|
-
return ASTMacro(ident, None)
|
3014
|
-
if self.skip_string(')'):
|
3015
|
-
return ASTMacro(ident, [])
|
3016
|
-
args = []
|
3017
|
-
while 1:
|
3018
|
-
self.skip_ws()
|
3019
|
-
if self.skip_string('...'):
|
3020
|
-
args.append(ASTMacroParameter(None, True))
|
3021
|
-
self.skip_ws()
|
3022
|
-
if not self.skip_string(')'):
|
3023
|
-
self.fail('Expected ")" after "..." in macro parameters.')
|
3024
|
-
break
|
3025
|
-
if not self.match(identifier_re):
|
3026
|
-
self.fail("Expected identifier in macro parameters.")
|
3027
|
-
nn = ASTNestedName([ASTIdentifier(self.matched_text)], rooted=False)
|
3028
|
-
# Allow named variadic args:
|
3029
|
-
# https://gcc.gnu.org/onlinedocs/cpp/Variadic-Macros.html
|
3030
|
-
self.skip_ws()
|
3031
|
-
if self.skip_string_and_ws('...'):
|
3032
|
-
args.append(ASTMacroParameter(nn, False, True))
|
3033
|
-
self.skip_ws()
|
3034
|
-
if not self.skip_string(')'):
|
3035
|
-
self.fail('Expected ")" after "..." in macro parameters.')
|
3036
|
-
break
|
3037
|
-
args.append(ASTMacroParameter(nn))
|
3038
|
-
if self.skip_string_and_ws(','):
|
3039
|
-
continue
|
3040
|
-
elif self.skip_string_and_ws(')'):
|
3041
|
-
break
|
3042
|
-
else:
|
3043
|
-
self.fail("Expected identifier, ')', or ',' in macro parameter list.")
|
3044
|
-
return ASTMacro(ident, args)
|
3045
|
-
|
3046
|
-
def _parse_struct(self) -> ASTStruct:
|
3047
|
-
name = self._parse_nested_name()
|
3048
|
-
return ASTStruct(name)
|
3049
|
-
|
3050
|
-
def _parse_union(self) -> ASTUnion:
|
3051
|
-
name = self._parse_nested_name()
|
3052
|
-
return ASTUnion(name)
|
3053
|
-
|
3054
|
-
def _parse_enum(self) -> ASTEnum:
|
3055
|
-
name = self._parse_nested_name()
|
3056
|
-
return ASTEnum(name)
|
3057
|
-
|
3058
|
-
def _parse_enumerator(self) -> ASTEnumerator:
|
3059
|
-
name = self._parse_nested_name()
|
3060
|
-
attrs = self._parse_attribute_list()
|
3061
|
-
self.skip_ws()
|
3062
|
-
init = None
|
3063
|
-
if self.skip_string('='):
|
3064
|
-
self.skip_ws()
|
3065
|
-
|
3066
|
-
def parser() -> ASTExpression:
|
3067
|
-
return self._parse_constant_expression()
|
3068
|
-
|
3069
|
-
initVal = self._parse_expression_fallback([], parser)
|
3070
|
-
init = ASTInitializer(initVal)
|
3071
|
-
return ASTEnumerator(name, init, attrs)
|
3072
|
-
|
3073
|
-
def parse_declaration(self, objectType: str, directiveType: str) -> ASTDeclaration:
|
3074
|
-
if objectType not in ('function', 'member',
|
3075
|
-
'macro', 'struct', 'union', 'enum', 'enumerator', 'type'):
|
3076
|
-
raise Exception('Internal error, unknown objectType "%s".' % objectType)
|
3077
|
-
if directiveType not in ('function', 'member', 'var',
|
3078
|
-
'macro', 'struct', 'union', 'enum', 'enumerator', 'type'):
|
3079
|
-
raise Exception('Internal error, unknown directiveType "%s".' % directiveType)
|
3080
|
-
|
3081
|
-
declaration: DeclarationType = None
|
3082
|
-
if objectType == 'member':
|
3083
|
-
declaration = self._parse_type_with_init(named=True, outer='member')
|
3084
|
-
elif objectType == 'function':
|
3085
|
-
declaration = self._parse_type(named=True, outer='function')
|
3086
|
-
elif objectType == 'macro':
|
3087
|
-
declaration = self._parse_macro()
|
3088
|
-
elif objectType == 'struct':
|
3089
|
-
declaration = self._parse_struct()
|
3090
|
-
elif objectType == 'union':
|
3091
|
-
declaration = self._parse_union()
|
3092
|
-
elif objectType == 'enum':
|
3093
|
-
declaration = self._parse_enum()
|
3094
|
-
elif objectType == 'enumerator':
|
3095
|
-
declaration = self._parse_enumerator()
|
3096
|
-
elif objectType == 'type':
|
3097
|
-
declaration = self._parse_type(named=True, outer='type')
|
3098
|
-
else:
|
3099
|
-
raise AssertionError()
|
3100
|
-
if objectType != 'macro':
|
3101
|
-
self.skip_ws()
|
3102
|
-
semicolon = self.skip_string(';')
|
3103
|
-
else:
|
3104
|
-
semicolon = False
|
3105
|
-
return ASTDeclaration(objectType, directiveType, declaration, semicolon)
|
3106
|
-
|
3107
|
-
def parse_namespace_object(self) -> ASTNestedName:
|
3108
|
-
return self._parse_nested_name()
|
3109
|
-
|
3110
|
-
def parse_xref_object(self) -> ASTNestedName:
|
3111
|
-
name = self._parse_nested_name()
|
3112
|
-
# if there are '()' left, just skip them
|
3113
|
-
self.skip_ws()
|
3114
|
-
self.skip_string('()')
|
3115
|
-
self.assert_end()
|
3116
|
-
return name
|
3117
|
-
|
3118
|
-
def parse_expression(self) -> ASTExpression | ASTType:
|
3119
|
-
pos = self.pos
|
3120
|
-
res: ASTExpression | ASTType = None
|
3121
|
-
try:
|
3122
|
-
res = self._parse_expression()
|
3123
|
-
self.skip_ws()
|
3124
|
-
self.assert_end()
|
3125
|
-
except DefinitionError as exExpr:
|
3126
|
-
self.pos = pos
|
3127
|
-
try:
|
3128
|
-
res = self._parse_type(False)
|
3129
|
-
self.skip_ws()
|
3130
|
-
self.assert_end()
|
3131
|
-
except DefinitionError as exType:
|
3132
|
-
header = "Error when parsing (type) expression."
|
3133
|
-
errs = []
|
3134
|
-
errs.append((exExpr, "If expression"))
|
3135
|
-
errs.append((exType, "If type"))
|
3136
|
-
raise self._make_multi_error(errs, header) from exType
|
3137
|
-
return res
|
3138
|
-
|
3139
|
-
|
3140
|
-
def _make_phony_error_name() -> ASTNestedName:
|
3141
|
-
return ASTNestedName([ASTIdentifier("PhonyNameDueToError")], rooted=False)
|
3142
|
-
|
3143
|
-
|
3144
|
-
class CObject(ObjectDescription[ASTDeclaration]):
|
3145
|
-
"""
|
3146
|
-
Description of a C language object.
|
3147
|
-
"""
|
3148
|
-
|
3149
|
-
option_spec: OptionSpec = {
|
3150
|
-
'noindexentry': directives.flag,
|
3151
|
-
'nocontentsentry': directives.flag,
|
3152
|
-
}
|
3153
|
-
|
3154
|
-
def _add_enumerator_to_parent(self, ast: ASTDeclaration) -> None:
|
3155
|
-
assert ast.objectType == 'enumerator'
|
3156
|
-
# find the parent, if it exists && is an enum
|
3157
|
-
# then add the name to the parent scope
|
3158
|
-
symbol = ast.symbol
|
3159
|
-
assert symbol
|
3160
|
-
assert symbol.ident is not None
|
3161
|
-
parentSymbol = symbol.parent
|
3162
|
-
assert parentSymbol
|
3163
|
-
if parentSymbol.parent is None:
|
3164
|
-
# TODO: we could warn, but it is somewhat equivalent to
|
3165
|
-
# enumeratorss, without the enum
|
3166
|
-
return # no parent
|
3167
|
-
parentDecl = parentSymbol.declaration
|
3168
|
-
if parentDecl is None:
|
3169
|
-
# the parent is not explicitly declared
|
3170
|
-
# TODO: we could warn, but?
|
3171
|
-
return
|
3172
|
-
if parentDecl.objectType != 'enum':
|
3173
|
-
# TODO: maybe issue a warning, enumerators in non-enums is weird,
|
3174
|
-
# but it is somewhat equivalent to enumeratorss, without the enum
|
3175
|
-
return
|
3176
|
-
if parentDecl.directiveType != 'enum':
|
3177
|
-
return
|
3178
|
-
|
3179
|
-
targetSymbol = parentSymbol.parent
|
3180
|
-
s = targetSymbol.find_identifier(symbol.ident, matchSelf=False, recurseInAnon=True,
|
3181
|
-
searchInSiblings=False)
|
3182
|
-
if s is not None:
|
3183
|
-
# something is already declared with that name
|
3184
|
-
return
|
3185
|
-
declClone = symbol.declaration.clone()
|
3186
|
-
declClone.enumeratorScopedSymbol = symbol
|
3187
|
-
Symbol(parent=targetSymbol, ident=symbol.ident,
|
3188
|
-
declaration=declClone,
|
3189
|
-
docname=self.env.docname, line=self.get_source_info()[1])
|
3190
|
-
|
3191
|
-
def add_target_and_index(self, ast: ASTDeclaration, sig: str,
|
3192
|
-
signode: TextElement) -> None:
|
3193
|
-
ids = []
|
3194
|
-
for i in range(1, _max_id + 1):
|
3195
|
-
try:
|
3196
|
-
id = ast.get_id(version=i)
|
3197
|
-
ids.append(id)
|
3198
|
-
except NoOldIdError:
|
3199
|
-
assert i < _max_id
|
3200
|
-
# let's keep the newest first
|
3201
|
-
ids = list(reversed(ids))
|
3202
|
-
newestId = ids[0]
|
3203
|
-
assert newestId # shouldn't be None
|
3204
|
-
|
3205
|
-
name = ast.symbol.get_full_nested_name().get_display_string().lstrip('.')
|
3206
|
-
if newestId not in self.state.document.ids:
|
3207
|
-
# always add the newest id
|
3208
|
-
assert newestId
|
3209
|
-
signode['ids'].append(newestId)
|
3210
|
-
# only add compatibility ids when there are no conflicts
|
3211
|
-
for id in ids[1:]:
|
3212
|
-
if not id: # is None when the element didn't exist in that version
|
3213
|
-
continue
|
3214
|
-
if id not in self.state.document.ids:
|
3215
|
-
signode['ids'].append(id)
|
3216
|
-
|
3217
|
-
self.state.document.note_explicit_target(signode)
|
3218
|
-
|
3219
|
-
if 'noindexentry' not in self.options:
|
3220
|
-
indexText = self.get_index_text(name)
|
3221
|
-
self.indexnode['entries'].append(('single', indexText, newestId, '', None))
|
3222
|
-
|
3223
|
-
@property
|
3224
|
-
def object_type(self) -> str:
|
3225
|
-
raise NotImplementedError()
|
3226
|
-
|
3227
|
-
@property
|
3228
|
-
def display_object_type(self) -> str:
|
3229
|
-
return self.object_type
|
3230
|
-
|
3231
|
-
def get_index_text(self, name: str) -> str:
|
3232
|
-
return _('%s (C %s)') % (name, self.display_object_type)
|
3233
|
-
|
3234
|
-
def parse_definition(self, parser: DefinitionParser) -> ASTDeclaration:
|
3235
|
-
return parser.parse_declaration(self.object_type, self.objtype)
|
3236
|
-
|
3237
|
-
def describe_signature(self, signode: TextElement, ast: ASTDeclaration,
|
3238
|
-
options: dict) -> None:
|
3239
|
-
ast.describe_signature(signode, 'lastIsName', self.env, options)
|
3240
|
-
|
3241
|
-
def run(self) -> list[Node]:
|
3242
|
-
env = self.state.document.settings.env # from ObjectDescription.run
|
3243
|
-
if 'c:parent_symbol' not in env.temp_data:
|
3244
|
-
root = env.domaindata['c']['root_symbol']
|
3245
|
-
env.temp_data['c:parent_symbol'] = root
|
3246
|
-
env.ref_context['c:parent_key'] = root.get_lookup_key()
|
3247
|
-
|
3248
|
-
# When multiple declarations are made in the same directive
|
3249
|
-
# they need to know about each other to provide symbol lookup for function parameters.
|
3250
|
-
# We use last_symbol to store the latest added declaration in a directive.
|
3251
|
-
env.temp_data['c:last_symbol'] = None
|
3252
|
-
return super().run()
|
3253
|
-
|
3254
|
-
def handle_signature(self, sig: str, signode: TextElement) -> ASTDeclaration:
|
3255
|
-
parentSymbol: Symbol = self.env.temp_data['c:parent_symbol']
|
3256
|
-
|
3257
|
-
parser = DefinitionParser(sig, location=signode, config=self.env.config)
|
3258
|
-
try:
|
3259
|
-
ast = self.parse_definition(parser)
|
3260
|
-
parser.assert_end()
|
3261
|
-
except DefinitionError as e:
|
3262
|
-
logger.warning(e, location=signode)
|
3263
|
-
# It is easier to assume some phony name than handling the error in
|
3264
|
-
# the possibly inner declarations.
|
3265
|
-
name = _make_phony_error_name()
|
3266
|
-
symbol = parentSymbol.add_name(name)
|
3267
|
-
self.env.temp_data['c:last_symbol'] = symbol
|
3268
|
-
raise ValueError from e
|
3269
|
-
|
3270
|
-
try:
|
3271
|
-
symbol = parentSymbol.add_declaration(
|
3272
|
-
ast, docname=self.env.docname, line=self.get_source_info()[1])
|
3273
|
-
# append the new declaration to the sibling list
|
3274
|
-
assert symbol.siblingAbove is None
|
3275
|
-
assert symbol.siblingBelow is None
|
3276
|
-
symbol.siblingAbove = self.env.temp_data['c:last_symbol']
|
3277
|
-
if symbol.siblingAbove is not None:
|
3278
|
-
assert symbol.siblingAbove.siblingBelow is None
|
3279
|
-
symbol.siblingAbove.siblingBelow = symbol
|
3280
|
-
self.env.temp_data['c:last_symbol'] = symbol
|
3281
|
-
except _DuplicateSymbolError as e:
|
3282
|
-
# Assume we are actually in the old symbol,
|
3283
|
-
# instead of the newly created duplicate.
|
3284
|
-
self.env.temp_data['c:last_symbol'] = e.symbol
|
3285
|
-
msg = __("Duplicate C declaration, also defined at %s:%s.\n"
|
3286
|
-
"Declaration is '.. c:%s:: %s'.")
|
3287
|
-
msg = msg % (e.symbol.docname, e.symbol.line, self.display_object_type, sig)
|
3288
|
-
logger.warning(msg, location=signode)
|
3289
|
-
|
3290
|
-
if ast.objectType == 'enumerator':
|
3291
|
-
self._add_enumerator_to_parent(ast)
|
3292
|
-
|
3293
|
-
# note: handle_signature may be called multiple time per directive,
|
3294
|
-
# if it has multiple signatures, so don't mess with the original options.
|
3295
|
-
options = dict(self.options)
|
3296
|
-
self.describe_signature(signode, ast, options)
|
3297
|
-
return ast
|
3298
|
-
|
3299
|
-
def before_content(self) -> None:
|
3300
|
-
lastSymbol: Symbol = self.env.temp_data['c:last_symbol']
|
3301
|
-
assert lastSymbol
|
3302
|
-
self.oldParentSymbol = self.env.temp_data['c:parent_symbol']
|
3303
|
-
self.oldParentKey: LookupKey = self.env.ref_context['c:parent_key']
|
3304
|
-
self.env.temp_data['c:parent_symbol'] = lastSymbol
|
3305
|
-
self.env.ref_context['c:parent_key'] = lastSymbol.get_lookup_key()
|
3306
|
-
|
3307
|
-
def after_content(self) -> None:
|
3308
|
-
self.env.temp_data['c:parent_symbol'] = self.oldParentSymbol
|
3309
|
-
self.env.ref_context['c:parent_key'] = self.oldParentKey
|
3310
|
-
|
3311
|
-
def make_old_id(self, name: str) -> str:
|
3312
|
-
"""Generate old styled node_id for C objects.
|
3313
|
-
|
3314
|
-
.. note:: Old Styled node_id was used until Sphinx-3.0.
|
3315
|
-
This will be removed in Sphinx-5.0.
|
3316
|
-
"""
|
3317
|
-
return 'c.' + name
|
3318
|
-
|
3319
|
-
|
3320
|
-
class CMemberObject(CObject):
|
3321
|
-
object_type = 'member'
|
3322
|
-
|
3323
|
-
@property
|
3324
|
-
def display_object_type(self) -> str:
|
3325
|
-
# the distinction between var and member is only cosmetic
|
3326
|
-
assert self.objtype in ('member', 'var')
|
3327
|
-
return self.objtype
|
3328
|
-
|
3329
|
-
|
3330
|
-
_function_doc_field_types = [
|
3331
|
-
TypedField('parameter', label=_('Parameters'),
|
3332
|
-
names=('param', 'parameter', 'arg', 'argument'),
|
3333
|
-
typerolename='expr', typenames=('type',)),
|
3334
|
-
GroupedField('retval', label=_('Return values'),
|
3335
|
-
names=('retvals', 'retval'),
|
3336
|
-
can_collapse=True),
|
3337
|
-
Field('returnvalue', label=_('Returns'), has_arg=False,
|
3338
|
-
names=('returns', 'return')),
|
3339
|
-
Field('returntype', label=_('Return type'), has_arg=False,
|
3340
|
-
names=('rtype',)),
|
3341
|
-
]
|
3342
|
-
|
3343
|
-
|
3344
|
-
class CFunctionObject(CObject):
|
3345
|
-
object_type = 'function'
|
3346
|
-
|
3347
|
-
doc_field_types = _function_doc_field_types.copy()
|
3348
|
-
|
3349
|
-
|
3350
|
-
class CMacroObject(CObject):
|
3351
|
-
object_type = 'macro'
|
3352
|
-
|
3353
|
-
doc_field_types = _function_doc_field_types.copy()
|
3354
|
-
|
3355
|
-
|
3356
|
-
class CStructObject(CObject):
|
3357
|
-
object_type = 'struct'
|
3358
|
-
|
3359
|
-
|
3360
|
-
class CUnionObject(CObject):
|
3361
|
-
object_type = 'union'
|
3362
|
-
|
3363
|
-
|
3364
|
-
class CEnumObject(CObject):
|
3365
|
-
object_type = 'enum'
|
3366
|
-
|
3367
|
-
|
3368
|
-
class CEnumeratorObject(CObject):
|
3369
|
-
object_type = 'enumerator'
|
3370
|
-
|
3371
|
-
|
3372
|
-
class CTypeObject(CObject):
|
3373
|
-
object_type = 'type'
|
3374
|
-
|
3375
|
-
|
3376
|
-
class CNamespaceObject(SphinxDirective):
|
3377
|
-
"""
|
3378
|
-
This directive is just to tell Sphinx that we're documenting stuff in
|
3379
|
-
namespace foo.
|
3380
|
-
"""
|
3381
|
-
|
3382
|
-
has_content = False
|
3383
|
-
required_arguments = 1
|
3384
|
-
optional_arguments = 0
|
3385
|
-
final_argument_whitespace = True
|
3386
|
-
option_spec: OptionSpec = {}
|
3387
|
-
|
3388
|
-
def run(self) -> list[Node]:
|
3389
|
-
rootSymbol = self.env.domaindata['c']['root_symbol']
|
3390
|
-
if self.arguments[0].strip() in ('NULL', '0', 'nullptr'):
|
3391
|
-
symbol = rootSymbol
|
3392
|
-
stack: list[Symbol] = []
|
3393
|
-
else:
|
3394
|
-
parser = DefinitionParser(self.arguments[0],
|
3395
|
-
location=self.get_location(),
|
3396
|
-
config=self.env.config)
|
3397
|
-
try:
|
3398
|
-
name = parser.parse_namespace_object()
|
3399
|
-
parser.assert_end()
|
3400
|
-
except DefinitionError as e:
|
3401
|
-
logger.warning(e, location=self.get_location())
|
3402
|
-
name = _make_phony_error_name()
|
3403
|
-
symbol = rootSymbol.add_name(name)
|
3404
|
-
stack = [symbol]
|
3405
|
-
self.env.temp_data['c:parent_symbol'] = symbol
|
3406
|
-
self.env.temp_data['c:namespace_stack'] = stack
|
3407
|
-
self.env.ref_context['c:parent_key'] = symbol.get_lookup_key()
|
3408
|
-
return []
|
3409
|
-
|
3410
|
-
|
3411
|
-
class CNamespacePushObject(SphinxDirective):
|
3412
|
-
has_content = False
|
3413
|
-
required_arguments = 1
|
3414
|
-
optional_arguments = 0
|
3415
|
-
final_argument_whitespace = True
|
3416
|
-
option_spec: OptionSpec = {}
|
3417
|
-
|
3418
|
-
def run(self) -> list[Node]:
|
3419
|
-
if self.arguments[0].strip() in ('NULL', '0', 'nullptr'):
|
3420
|
-
return []
|
3421
|
-
parser = DefinitionParser(self.arguments[0],
|
3422
|
-
location=self.get_location(),
|
3423
|
-
config=self.env.config)
|
3424
|
-
try:
|
3425
|
-
name = parser.parse_namespace_object()
|
3426
|
-
parser.assert_end()
|
3427
|
-
except DefinitionError as e:
|
3428
|
-
logger.warning(e, location=self.get_location())
|
3429
|
-
name = _make_phony_error_name()
|
3430
|
-
oldParent = self.env.temp_data.get('c:parent_symbol', None)
|
3431
|
-
if not oldParent:
|
3432
|
-
oldParent = self.env.domaindata['c']['root_symbol']
|
3433
|
-
symbol = oldParent.add_name(name)
|
3434
|
-
stack = self.env.temp_data.get('c:namespace_stack', [])
|
3435
|
-
stack.append(symbol)
|
3436
|
-
self.env.temp_data['c:parent_symbol'] = symbol
|
3437
|
-
self.env.temp_data['c:namespace_stack'] = stack
|
3438
|
-
self.env.ref_context['c:parent_key'] = symbol.get_lookup_key()
|
3439
|
-
return []
|
3440
|
-
|
3441
|
-
|
3442
|
-
class CNamespacePopObject(SphinxDirective):
|
3443
|
-
has_content = False
|
3444
|
-
required_arguments = 0
|
3445
|
-
optional_arguments = 0
|
3446
|
-
final_argument_whitespace = True
|
3447
|
-
option_spec: OptionSpec = {}
|
3448
|
-
|
3449
|
-
def run(self) -> list[Node]:
|
3450
|
-
stack = self.env.temp_data.get('c:namespace_stack', None)
|
3451
|
-
if not stack or len(stack) == 0:
|
3452
|
-
logger.warning("C namespace pop on empty stack. Defaulting to global scope.",
|
3453
|
-
location=self.get_location())
|
3454
|
-
stack = []
|
3455
|
-
else:
|
3456
|
-
stack.pop()
|
3457
|
-
if len(stack) > 0:
|
3458
|
-
symbol = stack[-1]
|
3459
|
-
else:
|
3460
|
-
symbol = self.env.domaindata['c']['root_symbol']
|
3461
|
-
self.env.temp_data['c:parent_symbol'] = symbol
|
3462
|
-
self.env.temp_data['c:namespace_stack'] = stack
|
3463
|
-
self.env.ref_context['cp:parent_key'] = symbol.get_lookup_key()
|
3464
|
-
return []
|
3465
|
-
|
3466
|
-
|
3467
|
-
class AliasNode(nodes.Element):
|
3468
|
-
def __init__(
|
3469
|
-
self,
|
3470
|
-
sig: str,
|
3471
|
-
aliasOptions: dict,
|
3472
|
-
document: Any,
|
3473
|
-
env: BuildEnvironment | None = None,
|
3474
|
-
parentKey: LookupKey | None = None,
|
3475
|
-
) -> None:
|
3476
|
-
super().__init__()
|
3477
|
-
self.sig = sig
|
3478
|
-
self.aliasOptions = aliasOptions
|
3479
|
-
self.document = document
|
3480
|
-
if env is not None:
|
3481
|
-
if 'c:parent_symbol' not in env.temp_data:
|
3482
|
-
root = env.domaindata['c']['root_symbol']
|
3483
|
-
env.temp_data['c:parent_symbol'] = root
|
3484
|
-
env.ref_context['c:parent_key'] = root.get_lookup_key()
|
3485
|
-
self.parentKey = env.ref_context['c:parent_key']
|
3486
|
-
else:
|
3487
|
-
assert parentKey is not None
|
3488
|
-
self.parentKey = parentKey
|
3489
|
-
|
3490
|
-
def copy(self) -> AliasNode:
|
3491
|
-
return self.__class__(self.sig, self.aliasOptions, self.document,
|
3492
|
-
env=None, parentKey=self.parentKey)
|
3493
|
-
|
3494
|
-
|
3495
|
-
class AliasTransform(SphinxTransform):
|
3496
|
-
default_priority = ReferencesResolver.default_priority - 1
|
3497
|
-
|
3498
|
-
def _render_symbol(self, s: Symbol, maxdepth: int, skipThis: bool,
|
3499
|
-
aliasOptions: dict, renderOptions: dict,
|
3500
|
-
document: Any) -> list[Node]:
|
3501
|
-
if maxdepth == 0:
|
3502
|
-
recurse = True
|
3503
|
-
elif maxdepth == 1:
|
3504
|
-
recurse = False
|
3505
|
-
else:
|
3506
|
-
maxdepth -= 1
|
3507
|
-
recurse = True
|
3508
|
-
|
3509
|
-
nodes: list[Node] = []
|
3510
|
-
if not skipThis:
|
3511
|
-
signode = addnodes.desc_signature('', '')
|
3512
|
-
nodes.append(signode)
|
3513
|
-
s.declaration.describe_signature(signode, 'markName', self.env, renderOptions)
|
3514
|
-
|
3515
|
-
if recurse:
|
3516
|
-
if skipThis:
|
3517
|
-
childContainer: list[Node] | addnodes.desc = nodes
|
3518
|
-
else:
|
3519
|
-
content = addnodes.desc_content()
|
3520
|
-
desc = addnodes.desc()
|
3521
|
-
content.append(desc)
|
3522
|
-
desc.document = document
|
3523
|
-
desc['domain'] = 'c'
|
3524
|
-
# 'desctype' is a backwards compatible attribute
|
3525
|
-
desc['objtype'] = desc['desctype'] = 'alias'
|
3526
|
-
desc['noindex'] = True
|
3527
|
-
childContainer = desc
|
3528
|
-
|
3529
|
-
for sChild in s.children:
|
3530
|
-
if sChild.declaration is None:
|
3531
|
-
continue
|
3532
|
-
childNodes = self._render_symbol(
|
3533
|
-
sChild, maxdepth=maxdepth, skipThis=False,
|
3534
|
-
aliasOptions=aliasOptions, renderOptions=renderOptions,
|
3535
|
-
document=document)
|
3536
|
-
childContainer.extend(childNodes)
|
3537
|
-
|
3538
|
-
if not skipThis and len(desc.children) != 0:
|
3539
|
-
nodes.append(content)
|
3540
|
-
return nodes
|
3541
|
-
|
3542
|
-
def apply(self, **kwargs: Any) -> None:
|
3543
|
-
for node in self.document.findall(AliasNode):
|
3544
|
-
sig = node.sig
|
3545
|
-
parentKey = node.parentKey
|
3546
|
-
try:
|
3547
|
-
parser = DefinitionParser(sig, location=node,
|
3548
|
-
config=self.env.config)
|
3549
|
-
name = parser.parse_xref_object()
|
3550
|
-
except DefinitionError as e:
|
3551
|
-
logger.warning(e, location=node)
|
3552
|
-
name = None
|
3553
|
-
|
3554
|
-
if name is None:
|
3555
|
-
# could not be parsed, so stop here
|
3556
|
-
signode = addnodes.desc_signature(sig, '')
|
3557
|
-
signode.clear()
|
3558
|
-
signode += addnodes.desc_name(sig, sig)
|
3559
|
-
node.replace_self(signode)
|
3560
|
-
continue
|
3561
|
-
|
3562
|
-
rootSymbol: Symbol = self.env.domains['c'].data['root_symbol']
|
3563
|
-
parentSymbol: Symbol = rootSymbol.direct_lookup(parentKey)
|
3564
|
-
if not parentSymbol:
|
3565
|
-
print("Target: ", sig)
|
3566
|
-
print("ParentKey: ", parentKey)
|
3567
|
-
print(rootSymbol.dump(1))
|
3568
|
-
assert parentSymbol # should be there
|
3569
|
-
|
3570
|
-
s = parentSymbol.find_declaration(
|
3571
|
-
name, 'any',
|
3572
|
-
matchSelf=True, recurseInAnon=True)
|
3573
|
-
if s is None:
|
3574
|
-
signode = addnodes.desc_signature(sig, '')
|
3575
|
-
node.append(signode)
|
3576
|
-
signode.clear()
|
3577
|
-
signode += addnodes.desc_name(sig, sig)
|
3578
|
-
|
3579
|
-
logger.warning("Could not find C declaration for alias '%s'." % name,
|
3580
|
-
location=node)
|
3581
|
-
node.replace_self(signode)
|
3582
|
-
continue
|
3583
|
-
# Declarations like .. var:: int Missing::var
|
3584
|
-
# may introduce symbols without declarations.
|
3585
|
-
# But if we skip the root then it is ok to start recursion from it.
|
3586
|
-
if not node.aliasOptions['noroot'] and s.declaration is None:
|
3587
|
-
signode = addnodes.desc_signature(sig, '')
|
3588
|
-
node.append(signode)
|
3589
|
-
signode.clear()
|
3590
|
-
signode += addnodes.desc_name(sig, sig)
|
3591
|
-
|
3592
|
-
logger.warning(
|
3593
|
-
"Can not render C declaration for alias '%s'. No such declaration." % name,
|
3594
|
-
location=node)
|
3595
|
-
node.replace_self(signode)
|
3596
|
-
continue
|
3597
|
-
|
3598
|
-
nodes = self._render_symbol(s, maxdepth=node.aliasOptions['maxdepth'],
|
3599
|
-
skipThis=node.aliasOptions['noroot'],
|
3600
|
-
aliasOptions=node.aliasOptions,
|
3601
|
-
renderOptions={}, document=node.document)
|
3602
|
-
node.replace_self(nodes)
|
3603
|
-
|
3604
|
-
|
3605
|
-
class CAliasObject(ObjectDescription):
|
3606
|
-
option_spec: OptionSpec = {
|
3607
|
-
'maxdepth': directives.nonnegative_int,
|
3608
|
-
'noroot': directives.flag,
|
3609
|
-
}
|
3610
|
-
|
3611
|
-
def run(self) -> list[Node]:
|
3612
|
-
"""
|
3613
|
-
On purpose this doesn't call the ObjectDescription version, but is based on it.
|
3614
|
-
Each alias signature may expand into multiple real signatures if 'noroot'.
|
3615
|
-
The code is therefore based on the ObjectDescription version.
|
3616
|
-
"""
|
3617
|
-
if ':' in self.name:
|
3618
|
-
self.domain, self.objtype = self.name.split(':', 1)
|
3619
|
-
else:
|
3620
|
-
self.domain, self.objtype = '', self.name
|
3621
|
-
|
3622
|
-
node = addnodes.desc()
|
3623
|
-
node.document = self.state.document
|
3624
|
-
node['domain'] = self.domain
|
3625
|
-
# 'desctype' is a backwards compatible attribute
|
3626
|
-
node['objtype'] = node['desctype'] = self.objtype
|
3627
|
-
node['noindex'] = True
|
3628
|
-
|
3629
|
-
self.names: list[str] = []
|
3630
|
-
aliasOptions = {
|
3631
|
-
'maxdepth': self.options.get('maxdepth', 1),
|
3632
|
-
'noroot': 'noroot' in self.options,
|
3633
|
-
}
|
3634
|
-
if aliasOptions['noroot'] and aliasOptions['maxdepth'] == 1:
|
3635
|
-
logger.warning("Error in C alias declaration."
|
3636
|
-
" Requested 'noroot' but 'maxdepth' 1."
|
3637
|
-
" When skipping the root declaration,"
|
3638
|
-
" need 'maxdepth' 0 for infinite or at least 2.",
|
3639
|
-
location=self.get_location())
|
3640
|
-
for sig in self.get_signatures():
|
3641
|
-
node.append(AliasNode(sig, aliasOptions, self.state.document, env=self.env))
|
3642
|
-
return [node]
|
3643
|
-
|
3644
|
-
|
3645
|
-
class CXRefRole(XRefRole):
|
3646
|
-
def process_link(self, env: BuildEnvironment, refnode: Element,
|
3647
|
-
has_explicit_title: bool, title: str, target: str) -> tuple[str, str]:
|
3648
|
-
refnode.attributes.update(env.ref_context)
|
3649
|
-
|
3650
|
-
if not has_explicit_title:
|
3651
|
-
# major hax: replace anon names via simple string manipulation.
|
3652
|
-
# Can this actually fail?
|
3653
|
-
title = anon_identifier_re.sub("[anonymous]", str(title))
|
3654
|
-
|
3655
|
-
if not has_explicit_title:
|
3656
|
-
target = target.lstrip('~') # only has a meaning for the title
|
3657
|
-
# if the first character is a tilde, don't display the module/class
|
3658
|
-
# parts of the contents
|
3659
|
-
if title[0:1] == '~':
|
3660
|
-
title = title[1:]
|
3661
|
-
dot = title.rfind('.')
|
3662
|
-
if dot != -1:
|
3663
|
-
title = title[dot + 1:]
|
3664
|
-
return title, target
|
3665
|
-
|
3666
|
-
|
3667
|
-
class CExprRole(SphinxRole):
|
3668
|
-
def __init__(self, asCode: bool) -> None:
|
3669
|
-
super().__init__()
|
3670
|
-
if asCode:
|
3671
|
-
# render the expression as inline code
|
3672
|
-
self.class_type = 'c-expr'
|
3673
|
-
else:
|
3674
|
-
# render the expression as inline text
|
3675
|
-
self.class_type = 'c-texpr'
|
3676
|
-
|
3677
|
-
def run(self) -> tuple[list[Node], list[system_message]]:
|
3678
|
-
text = self.text.replace('\n', ' ')
|
3679
|
-
parser = DefinitionParser(text, location=self.get_location(),
|
3680
|
-
config=self.env.config)
|
3681
|
-
# attempt to mimic XRefRole classes, except that...
|
3682
|
-
try:
|
3683
|
-
ast = parser.parse_expression()
|
3684
|
-
except DefinitionError as ex:
|
3685
|
-
logger.warning('Unparseable C expression: %r\n%s', text, ex,
|
3686
|
-
location=self.get_location())
|
3687
|
-
# see below
|
3688
|
-
return [addnodes.desc_inline('c', text, text, classes=[self.class_type])], []
|
3689
|
-
parentSymbol = self.env.temp_data.get('c:parent_symbol', None)
|
3690
|
-
if parentSymbol is None:
|
3691
|
-
parentSymbol = self.env.domaindata['c']['root_symbol']
|
3692
|
-
# ...most if not all of these classes should really apply to the individual references,
|
3693
|
-
# not the container node
|
3694
|
-
signode = addnodes.desc_inline('c', classes=[self.class_type])
|
3695
|
-
ast.describe_signature(signode, 'markType', self.env, parentSymbol)
|
3696
|
-
return [signode], []
|
3697
|
-
|
3698
|
-
|
3699
|
-
class CDomain(Domain):
|
3700
|
-
"""C language domain."""
|
3701
|
-
name = 'c'
|
3702
|
-
label = 'C'
|
3703
|
-
object_types = {
|
3704
|
-
# 'identifier' is the one used for xrefs generated in signatures, not in roles
|
3705
|
-
'member': ObjType(_('member'), 'var', 'member', 'data', 'identifier'),
|
3706
|
-
'var': ObjType(_('variable'), 'var', 'member', 'data', 'identifier'),
|
3707
|
-
'function': ObjType(_('function'), 'func', 'identifier', 'type'),
|
3708
|
-
'macro': ObjType(_('macro'), 'macro', 'identifier'),
|
3709
|
-
'struct': ObjType(_('struct'), 'struct', 'identifier', 'type'),
|
3710
|
-
'union': ObjType(_('union'), 'union', 'identifier', 'type'),
|
3711
|
-
'enum': ObjType(_('enum'), 'enum', 'identifier', 'type'),
|
3712
|
-
'enumerator': ObjType(_('enumerator'), 'enumerator', 'identifier'),
|
3713
|
-
'type': ObjType(_('type'), 'identifier', 'type'),
|
3714
|
-
# generated object types
|
3715
|
-
'functionParam': ObjType(_('function parameter'), 'identifier', 'var', 'member', 'data'), # noqa: E501
|
3716
|
-
}
|
3717
|
-
|
3718
|
-
directives = {
|
3719
|
-
'member': CMemberObject,
|
3720
|
-
'var': CMemberObject,
|
3721
|
-
'function': CFunctionObject,
|
3722
|
-
'macro': CMacroObject,
|
3723
|
-
'struct': CStructObject,
|
3724
|
-
'union': CUnionObject,
|
3725
|
-
'enum': CEnumObject,
|
3726
|
-
'enumerator': CEnumeratorObject,
|
3727
|
-
'type': CTypeObject,
|
3728
|
-
# scope control
|
3729
|
-
'namespace': CNamespaceObject,
|
3730
|
-
'namespace-push': CNamespacePushObject,
|
3731
|
-
'namespace-pop': CNamespacePopObject,
|
3732
|
-
# other
|
3733
|
-
'alias': CAliasObject
|
3734
|
-
}
|
3735
|
-
roles = {
|
3736
|
-
'member': CXRefRole(),
|
3737
|
-
'data': CXRefRole(),
|
3738
|
-
'var': CXRefRole(),
|
3739
|
-
'func': CXRefRole(fix_parens=True),
|
3740
|
-
'macro': CXRefRole(),
|
3741
|
-
'struct': CXRefRole(),
|
3742
|
-
'union': CXRefRole(),
|
3743
|
-
'enum': CXRefRole(),
|
3744
|
-
'enumerator': CXRefRole(),
|
3745
|
-
'type': CXRefRole(),
|
3746
|
-
'expr': CExprRole(asCode=True),
|
3747
|
-
'texpr': CExprRole(asCode=False)
|
3748
|
-
}
|
3749
|
-
initial_data: dict[str, Symbol | dict[str, tuple[str, str, str]]] = {
|
3750
|
-
'root_symbol': Symbol(None, None, None, None, None),
|
3751
|
-
'objects': {}, # fullname -> docname, node_id, objtype
|
3752
|
-
}
|
3753
|
-
|
3754
|
-
def clear_doc(self, docname: str) -> None:
|
3755
|
-
if Symbol.debug_show_tree:
|
3756
|
-
print("clear_doc:", docname)
|
3757
|
-
print("\tbefore:")
|
3758
|
-
print(self.data['root_symbol'].dump(1))
|
3759
|
-
print("\tbefore end")
|
3760
|
-
|
3761
|
-
rootSymbol = self.data['root_symbol']
|
3762
|
-
rootSymbol.clear_doc(docname)
|
3763
|
-
|
3764
|
-
if Symbol.debug_show_tree:
|
3765
|
-
print("\tafter:")
|
3766
|
-
print(self.data['root_symbol'].dump(1))
|
3767
|
-
print("\tafter end")
|
3768
|
-
print("clear_doc end:", docname)
|
3769
|
-
|
3770
|
-
def process_doc(self, env: BuildEnvironment, docname: str,
|
3771
|
-
document: nodes.document) -> None:
|
3772
|
-
if Symbol.debug_show_tree:
|
3773
|
-
print("process_doc:", docname)
|
3774
|
-
print(self.data['root_symbol'].dump(0))
|
3775
|
-
print("process_doc end:", docname)
|
3776
|
-
|
3777
|
-
def process_field_xref(self, pnode: pending_xref) -> None:
|
3778
|
-
pnode.attributes.update(self.env.ref_context)
|
3779
|
-
|
3780
|
-
def merge_domaindata(self, docnames: list[str], otherdata: dict) -> None:
|
3781
|
-
if Symbol.debug_show_tree:
|
3782
|
-
print("merge_domaindata:")
|
3783
|
-
print("\tself:")
|
3784
|
-
print(self.data['root_symbol'].dump(1))
|
3785
|
-
print("\tself end")
|
3786
|
-
print("\tother:")
|
3787
|
-
print(otherdata['root_symbol'].dump(1))
|
3788
|
-
print("\tother end")
|
3789
|
-
print("merge_domaindata end")
|
3790
|
-
|
3791
|
-
self.data['root_symbol'].merge_with(otherdata['root_symbol'],
|
3792
|
-
docnames, self.env)
|
3793
|
-
ourObjects = self.data['objects']
|
3794
|
-
for fullname, (fn, id_, objtype) in otherdata['objects'].items():
|
3795
|
-
if fn in docnames:
|
3796
|
-
if fullname not in ourObjects:
|
3797
|
-
ourObjects[fullname] = (fn, id_, objtype)
|
3798
|
-
# no need to warn on duplicates, the symbol merge already does that
|
3799
|
-
|
3800
|
-
def _resolve_xref_inner(self, env: BuildEnvironment, fromdocname: str, builder: Builder,
|
3801
|
-
typ: str, target: str, node: pending_xref,
|
3802
|
-
contnode: Element) -> tuple[Element | None, str | None]:
|
3803
|
-
parser = DefinitionParser(target, location=node, config=env.config)
|
3804
|
-
try:
|
3805
|
-
name = parser.parse_xref_object()
|
3806
|
-
except DefinitionError as e:
|
3807
|
-
logger.warning('Unparseable C cross-reference: %r\n%s', target, e,
|
3808
|
-
location=node)
|
3809
|
-
return None, None
|
3810
|
-
parentKey: LookupKey = node.get("c:parent_key", None)
|
3811
|
-
rootSymbol = self.data['root_symbol']
|
3812
|
-
if parentKey:
|
3813
|
-
parentSymbol: Symbol = rootSymbol.direct_lookup(parentKey)
|
3814
|
-
if not parentSymbol:
|
3815
|
-
print("Target: ", target)
|
3816
|
-
print("ParentKey: ", parentKey)
|
3817
|
-
print(rootSymbol.dump(1))
|
3818
|
-
assert parentSymbol # should be there
|
3819
|
-
else:
|
3820
|
-
parentSymbol = rootSymbol
|
3821
|
-
s = parentSymbol.find_declaration(name, typ,
|
3822
|
-
matchSelf=True, recurseInAnon=True)
|
3823
|
-
if s is None or s.declaration is None:
|
3824
|
-
return None, None
|
3825
|
-
|
3826
|
-
# TODO: check role type vs. object type
|
3827
|
-
|
3828
|
-
declaration = s.declaration
|
3829
|
-
displayName = name.get_display_string()
|
3830
|
-
docname = s.docname
|
3831
|
-
assert docname
|
3832
|
-
|
3833
|
-
return make_refnode(builder, fromdocname, docname,
|
3834
|
-
declaration.get_newest_id(), contnode, displayName
|
3835
|
-
), declaration.objectType
|
3836
|
-
|
3837
|
-
def resolve_xref(self, env: BuildEnvironment, fromdocname: str, builder: Builder,
|
3838
|
-
typ: str, target: str, node: pending_xref,
|
3839
|
-
contnode: Element) -> Element | None:
|
3840
|
-
return self._resolve_xref_inner(env, fromdocname, builder, typ,
|
3841
|
-
target, node, contnode)[0]
|
3842
|
-
|
3843
|
-
def resolve_any_xref(self, env: BuildEnvironment, fromdocname: str, builder: Builder,
|
3844
|
-
target: str, node: pending_xref, contnode: Element
|
3845
|
-
) -> list[tuple[str, Element]]:
|
3846
|
-
with logging.suppress_logging():
|
3847
|
-
retnode, objtype = self._resolve_xref_inner(env, fromdocname, builder,
|
3848
|
-
'any', target, node, contnode)
|
3849
|
-
if retnode:
|
3850
|
-
return [('c:' + self.role_for_objtype(objtype), retnode)]
|
3851
|
-
return []
|
3852
|
-
|
3853
|
-
def get_objects(self) -> Iterator[tuple[str, str, str, str, str, int]]:
|
3854
|
-
rootSymbol = self.data['root_symbol']
|
3855
|
-
for symbol in rootSymbol.get_all_symbols():
|
3856
|
-
if symbol.declaration is None:
|
3857
|
-
continue
|
3858
|
-
assert symbol.docname
|
3859
|
-
fullNestedName = symbol.get_full_nested_name()
|
3860
|
-
name = str(fullNestedName).lstrip('.')
|
3861
|
-
dispname = fullNestedName.get_display_string().lstrip('.')
|
3862
|
-
objectType = symbol.declaration.objectType
|
3863
|
-
docname = symbol.docname
|
3864
|
-
newestId = symbol.declaration.get_newest_id()
|
3865
|
-
yield (name, dispname, objectType, docname, newestId, 1)
|
3866
|
-
|
3867
|
-
|
3868
|
-
def setup(app: Sphinx) -> dict[str, Any]:
|
3869
|
-
app.add_domain(CDomain)
|
3870
|
-
app.add_config_value("c_id_attributes", [], 'env')
|
3871
|
-
app.add_config_value("c_paren_attributes", [], 'env')
|
3872
|
-
app.add_config_value("c_extra_keywords", _macroKeywords, 'env')
|
3873
|
-
app.add_post_transform(AliasTransform)
|
3874
|
-
|
3875
|
-
return {
|
3876
|
-
'version': 'builtin',
|
3877
|
-
'env_version': 2,
|
3878
|
-
'parallel_read_safe': True,
|
3879
|
-
'parallel_write_safe': True,
|
3880
|
-
}
|